1.初始化node 項目vue
2.安裝須要部件node
3.編寫簡單代碼web
routers=>:index.js login.js users.jsexpress
根目錄 index.jsjson
var express=require('express'); var app=express(); var consign=require('consign'); var bodyparser = require('body-parser'); app.use(bodyparser.urlencoded({extende:true})); app.use(bodyparser.json()); //設置跨域 app.all('*', function(req, res, next) { res.header("Access-Control-Allow-Origin", "*"); res.header("Access-Control-Allow-Headers", "X-Requested-With"); res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS"); res.header("X-Powered-By",' 3.2.1'); res.header("Content-Type", "application/json;charset=utf-8"); next(); }); consign({verbose: false}) .include("./config.js") .then("./routers") .into(app); //配置服務端口 var server = app.listen(3000, function () { var host = server.address().address; var port = server.address().port; console.log('vue api listening at http://%s:%s', host, port); })
根目錄config.jsapi
module.exports ={ users:[ { username:'admin', pwd:'U2FsdGVkX18RavhpxcS6QkHK1Je08MQf7pmNqF41Mug=',id:1 }, { username:'test', pwd:'U2FsdGVkX18RavhpxcS6QkHK1Je08MQf7pmNqF41Mug=',id:2 } ], aeskey:'lin.su', jwtSecret: "lin.su", jwtSession: {session: false} };
routers:index.js跨域
module.exports = app => { app.get("/", (req, res) => { res.json({code: "200",msg:'vue 數據接口正常啓動'}); }); };
routers:login.jssession
var jwt = require('jwt-simple'); const tokenExpiresTime = 1000 * 60 * 60 * 24 module.exports = app => { var jstSecret=app.config.jwtSecret; app.post("/login", (req, res) => { var username=req.body.username; var upwd=req.body.password; var result=false; var uinfo; for(var i=0;i<app.config.users.length;i++){ if(app.config.users[i].username == username){ result=true; uinfo=app.config.users[i]; break; } } const payload = { user:uinfo.username, environment:'web', expires: Date.now() + tokenExpiresTime }; if(result && uinfo.pwd == upwd){ delete uinfo.pwd; res.json({ code:200, token: jwt.encode(payload, jstSecret),userinfo:uinfo }); } else{ res.json({ code:500,msg: '用戶名密碼錯誤' }); } }); };
routers:users.jsapp
module.exports = app => { app.get("/user",(req, res) => { res.json({code: "200",msg:'success'}); }); app.get("/user/info",(req,res) => { res.json({code: "200",msg:'success'}); }); app.post("/users", (req, res) => { var result=req.body; res.json({code: "200",msg:JSON.stringify(result)}); }); };
4.運行效果post