日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > vue >内容正文

vue

vue+express 构建后台管理系统

發布時間:2023/12/15 vue 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 vue+express 构建后台管理系统 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一個vue+express 構建的后臺管理系統

說明:

vue+express 構建的后臺管理系統,包括登錄、注冊、表格的增刪改查 github 在線

1.修復mysql無法訪問

搭建vue項目:

1.安裝vue-cli腳手架

npm install -g vue-cli 復制代碼

2.創建基于webpack模版的項目

vue init webpack my-express 復制代碼

3.安裝包依賴并運行

cd my-express npm install npm run dev 復制代碼

vue項目基于iview-admin改造的

通過應用生成器工具 express創建一個應用的骨架:

1.連接數據庫

在config創建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創建token.js

const crypto = require('jsonwebtoken') const secret = "JWT-TOKEN" const token={createToken:function(obj,timeout){// Token 數據let payload = {name: obj.username,admin: true};// 密鑰// 簽發 Tokenlet 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.部署阿里云

創建實例

添加安全組允許3000端口

使用putty連接linux服務器,將express項目壓縮上傳

注:表述能力有限如果有什么問題或探討可以加qq:1726861462

如果對你有幫助勞駕給個star github

轉載于:https://juejin.im/post/5b56dc6be51d451956052dc1

總結

以上是生活随笔為你收集整理的vue+express 构建后台管理系统的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。