您好,登錄后才能下訂單哦!
vue+express 構(gòu)建后臺管理系統(tǒng)?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
搭建vue項目:
1.安裝vue-cli腳手架
npm install -g vue-cli
2.創(chuàng)建基于webpack模版的項目
vue init webpack my-express
3.安裝包依賴并運行
cd my-express npm install npm run dev
vue項目基于iview-admin改造的
通過應(yīng)用生成器工具 express創(chuàng)建一個應(yīng)用的骨架:
1.連接數(shù)據(jù)庫
在config創(chuàng)建db.js
var mysql = require("mysql"); var connection = mysql.createConnection({ host:"", port: 3306, user:"root", password:"", database:"", useConnectionPooling: true }); function query(sql,data,callback){ // connection.connect() // pool.getConnection(function(err,connection){ connection.query(sql,data,function (err,rows) { callback(err,rows); // connection.release(); // connection.end() }); // }); } exports.query = query;
在routers路由文件下引入
var express = require('express'); var router = express.Router(); var db = require("../config/db"); const jwt = require('jsonwebtoken') const token = require("../config/token") var data={data:'',meta:{code:'200',message:''}} /* GET users listing. */ router.post('/add', function(req, res, next) { let username = req.body.username; let password = req.body.password; db.query("SELECT username FROM users where username=(?)",[username],function(err,rows){ console.log(err,rows) if(rows.length>0){ data={data:'',meta:{code:'500',message:'用戶名存在'}} res.send(data) }else{ db.query("INSERT INTO `users` (`username`,`password`) VALUES (?,?)",[username,password],function(err,rows){ data={data:'',meta:{code:'200',message:'注冊成功'}} res.send(data) }); } }); });
2.加入token驗證
安裝jsonwebtoken
npm install jsonwebtoken
在config創(chuàng)建token.js
const crypto = require('jsonwebtoken') const secret = "JWT-TOKEN" const token={ createToken:function(obj,timeout){ // Token 數(shù)據(jù) let payload = { name: obj.username, admin: true }; // 密鑰 // 簽發(fā) Token let tokens = crypto.sign(payload, secret, { expiresIn: 3600}) return tokens; }, decodeToken:function(tokens){ console.log(tokens) let res = false; crypto.verify(tokens, secret , function(err,decoded) { if(err){ res = {'flag':false,'decoded':decoded} }else{ res = {'flag':true,'decoded':decoded} } }) return res; }, checkToken:function(token){ var resDecode=this.decodeToken(token); if(!resDecode){ return false; } //是否過期 var expState=(parseInt(Date.now()/1000)-parseInt(resDecode.payload.created))>parseInt(resDecode.payload.exp)?false:true; if(resDecode.signature===resDecode.checkSignature&&expState){ return true; } return false; } }; module.exports=exports=token;
在app.js驗證token是否過期,過去返回401
app.all('*', function(req, res, next) { res.header("Access-Control-Allow-Origin", "*"); res.header('Access-Control-Allow-Methods', 'PUT, GET, POST, DELETE, OPTIONS'); res.header("Access-Control-Allow-Headers", "Content-Type, access_token, X-Requested-With") // res.header("Content-Type", "application/json;charset=utf-8"); console.log(req.originalUrl,'11111') if(rouetpass.indexOf(req.originalUrl) > -1 || req.originalUrl.split('/').indexOf('static') > -1){ next() }else{ if (req.method != "OPTIONS"){ var accesstoken = req.headers['access_token']; let datatoken = token.decodeToken(accesstoken) // console.log(data) if(datatoken.flag){ next() }else{ data.meta.code=401; res.send(data) } }else{ next() } } });
項目部署:
1.將vue項目打包后放在express項目public文件夾下,通http://localhost:3000即可以訪問。
2.部署阿里云
創(chuàng)建實例
添加安全組允許3000端口
看完上述內(nèi)容,你們掌握vue+express 構(gòu)建后臺管理系統(tǒng)的方法了嗎?如果還想學到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。