vue+express 構(gòu)建后臺(tái)管理系統(tǒng)的示例代碼
一個(gè)vue+express 構(gòu)建的后臺(tái)管理系統(tǒng)
說(shuō)明:
vue+express 構(gòu)建的后臺(tái)管理系統(tǒng),包括登錄、注冊(cè)、表格的增刪改查
搭建vue項(xiàng)目:
1.安裝vue-cli腳手架
npm install -g vue-cli
2.創(chuàng)建基于webpack模版的項(xiàng)目
vue init webpack my-express
3.安裝包依賴并運(yùn)行
cd my-express npm install npm run dev
vue項(xiàng)目基于iview-admin改造的
通過(guò)應(yīng)用生成器工具 express創(chuàng)建一個(gè)應(yīng)用的骨架:
1.連接數(shù)據(jù)庫(kù)
在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:'注冊(cè)成功'}} res.send(data) }); } }); });
2.加入token驗(yàn)證
安裝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; } //是否過(guò)期 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驗(yàn)證token是否過(guò)期,過(guò)去返回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() } } });
項(xiàng)目部署:
1.將vue項(xiàng)目打包后放在express項(xiàng)目public文件夾下,通http://localhost:3000即可以訪問(wèn)。
2.部署阿里云
創(chuàng)建實(shí)例
添加安全組允許3000端口
使用putty連接linux服務(wù)器,將express項(xiàng)目壓縮上傳
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 詳解Vue后臺(tái)管理系統(tǒng)開(kāi)發(fā)日??偨Y(jié)(組件PageHeader)
- vue中如何實(shí)現(xiàn)后臺(tái)管理系統(tǒng)的權(quán)限控制的方法步驟
- 淺談vue后臺(tái)管理系統(tǒng)權(quán)限控制思考與實(shí)踐
- vue中如何實(shí)現(xiàn)后臺(tái)管理系統(tǒng)的權(quán)限控制的方法示例
- 詳解使用VUE搭建后臺(tái)管理系統(tǒng)(vue-cli更新至3.0)
- 使用vue.js2.0 + ElementUI開(kāi)發(fā)后臺(tái)管理系統(tǒng)詳細(xì)教程(一)
- 使用vue.js2.0 + ElementUI開(kāi)發(fā)后臺(tái)管理系統(tǒng)詳細(xì)教程(二)
- vue+element-ui JYAdmin后臺(tái)管理系統(tǒng)模板解析
相關(guān)文章
Vue解析剪切板圖片并實(shí)現(xiàn)發(fā)送功能
這篇文章主要介紹了Vue解析剪切板圖片并實(shí)現(xiàn)發(fā)送功能,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02解決vue?eslint開(kāi)發(fā)嚴(yán)格模式警告錯(cuò)誤的問(wèn)題
這篇文章主要介紹了解決vue?eslint開(kāi)發(fā)嚴(yán)格模式警告錯(cuò)誤的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04使用Vue的slot插槽分發(fā)父組件內(nèi)容實(shí)現(xiàn)高度復(fù)用、更加靈活的組件(推薦)
這篇文章主要介紹了使用Vue的slot插槽分發(fā)父組件內(nèi)容實(shí)現(xiàn)高度復(fù)用、更加靈活的組件 ,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2018-05-05vuejs+element-ui+laravel5.4上傳文件的示例代碼
本篇文章主要介紹了vuejs+element-ui+laravel5.4上傳文件的示例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下2017-08-08VUE實(shí)現(xiàn)大轉(zhuǎn)盤抽獎(jiǎng)
營(yíng)運(yùn)三寶(九宮格、大轉(zhuǎn)盤、老虎機(jī),當(dāng)然此三寶當(dāng)然是最基礎(chǔ)的營(yíng)銷運(yùn)營(yíng)手段),本片文章聊聊大轉(zhuǎn)盤,轉(zhuǎn)盤的實(shí)現(xiàn)邏輯應(yīng)該是營(yíng)銷方案較為簡(jiǎn)單的一種了,本文將介紹如何實(shí)現(xiàn)大轉(zhuǎn)盤抽獎(jiǎng),感興趣的朋友可以參考下2021-05-05Vue數(shù)據(jù)變化后頁(yè)面更新詳細(xì)介紹
這篇文章主要介紹了Vue在數(shù)據(jù)發(fā)生變化后是如何更新頁(yè)面的,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2022-10-10談?wù)勔騐ue.js引發(fā)關(guān)于getter和setter的思考
最近因?yàn)楣镜男马?xiàng)目決定使用Vue.js來(lái)做,但在使用的過(guò)程中發(fā)現(xiàn)了一個(gè)有趣的事情,因?yàn)榘l(fā)現(xiàn)的這個(gè)事情展開(kāi)了一些對(duì)于getter和setter的思考,具體是什么下面通過(guò)這篇文章來(lái)一起看看吧,有需要的朋友們可以參考學(xué)習(xí)。2016-12-12