一个vue+express 构建的后台管理系统
说明:
vue+express 构建的后台管理系统,包括登录、注册、表格的增删改查
github 在线
搭建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 }; // 密钥 // 签发 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)"htmlcode">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:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
暂无评论...
更新日志
2024年11月27日
2024年11月27日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]