摘要:部署阿里云创建实例添加安全组允许端口使用连接服务器将项目压缩上传注表述能力有限如果有什么问题或探讨可以加如果对你有帮助劳驾给个
一个vue+express 构建的后台管理系统 说明: vue+express 构建的后台管理系统,包括登录、注册、表格的增删改查
github 在线
npm install -g vue-cli
vue init webpack my-express
cd my-express npm install npm run dev
vue项目基于iview-admin改造的通过应用生成器工具 express创建一个应用的骨架:
在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) }); } }); });
安装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() } } });项目部署:
创建实例
添加安全组允许3000端口
使用putty连接linux服务器,将express项目压缩上传注:表述能力有限如果有什么问题或探讨可以加qq:1726861462 如果对你有帮助劳驾给个star github
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/96253.html
摘要:一前言提纲基于和框架写的一个全栈购物商城,记录项目过程中遇到的一些问题以及经验和技巧。服务端技术栈登录授权用认证机制,来实现登录登出。服务器配置和缓存策略,根据不同的来代理。申请证书全站升级到,配置的协议。一、前言提纲 基于Vue和Express框架写的一个全栈购物商城,记录项目过程中遇到的一些问题以及经验和技巧。 二、历史版本 基于Vue-CLI2.0:点我查看 这个分支版本是一两年前...
摘要:一前言提纲基于和框架写的一个全栈购物商城,记录项目过程中遇到的一些问题以及经验和技巧。服务端技术栈登录授权用认证机制,来实现登录登出。服务器配置和缓存策略,根据不同的来代理。申请证书全站升级到,配置的协议。 一、前言提纲 基于Vue和Express框架写的一个全栈购物商城,记录项目过程中遇到的一些问题以及经验和技巧。 二、历史版本 基于Vue-CLI2.0:点我查看这个分支版本是一两...
摘要:其中用来完成请求,将添加的原型上后就不需要再在每个需要使用它的页面引入了每个页面都相当于一个组件,文件以结尾,第一次启动成功时看到的页面就是组件,路径。 学习笔记...在线地址:cl8023.com github 数据库已改为mongodb 快速搭建 node 后端服务Github-quick-node-server 准备工作 安装node,这是必须的 新版node自带npm...
摘要:注册成功后会返回注册用户的此就是上面说到的,用于用户登陆的基础,请保管好。 地址 https://github.com/billyhoomm...http://blog.billyhu.com 说明(Instructions) 本项目后台基于express、mongodb,前台基于Vue2.0全家桶、bootstrap、scss预编译器以及一众工具类插件 项目前后台代码在同一个目录中...
阅读 1858·2021-11-22 15:25
阅读 1223·2021-11-19 09:40
阅读 1800·2021-09-27 13:57
阅读 966·2021-09-22 15:10
阅读 943·2021-08-16 11:01
阅读 2918·2021-07-23 17:51
阅读 725·2019-08-30 15:55
阅读 799·2019-08-30 13:58