Vue+Iview+Node 搭建數據模擬接口

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

相關文章
相關標籤/搜索