vue+express 构建后台管理系统的示例代码
程序员文章站
2022-06-14 12:58:05
一个vue+express 构建的后台管理系统
说明:
vue+express 构建的后台管理系统,包括登录、注册、表格的增删改查
搭建vue项目:
1.安装v...
一个vue+express 构建的后台管理系统
说明:
vue+express 构建的后台管理系统,包括登录、注册、表格的增删改查
搭建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)?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项目压缩上传
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: 在vue项目中,使用axios跨域处理
推荐阅读
-
vue+express 构建后台管理系统的示例代码
-
构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(24)-权限管理系统-将权限授权给角色
-
vue中如何实现后台管理系统的权限控制的方法示例
-
构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(26)-权限管理系统-分配角色给用户
-
基于Vue实现后台系统权限控制的示例代码
-
构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(29)-T4模版
-
3分钟纯 Java 注解搭个管理系统的示例代码
-
React全家桶+Material-ui构建的后台管理系统
-
react配合antd组件实现的管理系统示例代码
-
Python实现一个简单的毕业生信息管理系统的示例代码