vue+express 构建后台管理系统的示例代码


Posted in Javascript onJuly 19, 2018

一个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)?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.部署阿里云

创建实例

vue+express 构建后台管理系统的示例代码

添加安全组允许3000端口

vue+express 构建后台管理系统的示例代码

使用putty连接linux服务器,将express项目压缩上传

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery实现简单的拖拽效果实例兼容所有主流浏览器(优化篇)
Jun 28 Javascript
利用jquery写的左右轮播图特效
Feb 12 Javascript
JavaScript比较当前时间是否在指定时间段内的方法
Aug 02 Javascript
jquery判断页面网址是否有效的两种方法
Dec 11 Javascript
AngularJS动态绑定ng-options的ng-model实例代码
Jun 21 Javascript
js 显示日期时间的实例(时间过一秒加1)
Oct 25 Javascript
微信小程序之圆形进度条实现思路
Feb 22 Javascript
RequireJS用法简单示例
Aug 20 Javascript
vue单页应用在页面刷新时保留状态数据的方法
Sep 21 Javascript
在vue和element-ui的table中实现分页复选功能
Dec 04 Javascript
vue 动态给每个页面添加title、关键词和描述的方法
Aug 28 Javascript
vue 计算属性和侦听器的使用小结
Jan 25 Vue.js
微信小程序表单弹窗实例
Jul 19 #Javascript
vue用递归组件写树形控件的实例代码
Jul 19 #Javascript
如何理解Vue的v-model指令的使用方法
Jul 19 #Javascript
JavaScript去掉数组重复项的方法分析【测试可用】
Jul 19 #Javascript
微信小程序自定义对话框弹出和隐藏动画
Jul 19 #Javascript
浅谈Vue初学之props的驼峰命名
Jul 19 #Javascript
解决vue-cli3 使用子目录部署问题
Jul 19 #Javascript
You might like
《五等分的花嫁》漫画完结!2020年10月第2期TV动画制作组换血!
2020/03/06 日漫
PHP中echo,print_r与var_dump区别分析
2014/09/29 PHP
php实现微信公众平台账号自定义菜单类
2014/12/02 PHP
php操作(删除,提取,增加)zip文件方法详解
2015/03/12 PHP
CodeIgniter配置之routes.php用法实例分析
2016/01/19 PHP
适合PHP初学者阅读的4本经典书籍
2016/09/23 PHP
php实现页面纯静态的实例代码
2017/06/21 PHP
php定期拉取数据对比方法实例
2019/09/22 PHP
用htc组件制作windows选项卡
2007/01/13 Javascript
jquery validate使用攻略 第四步
2010/07/01 Javascript
JS获取网页属性包括宽、高等等
2014/04/03 Javascript
深入探究JavaScript中for循环的效率问题及相关优化
2016/03/13 Javascript
Js调用Java方法并互相传参的简单实例
2016/08/11 Javascript
Vue.js实战之组件的进阶
2017/04/04 Javascript
vue-cli扩展多模块打包的示例代码
2018/04/09 Javascript
vuex与组件联合使用的方法
2018/05/10 Javascript
使用Layer组件弹出多个对话框(非嵌套)与关闭及刷新的例子
2019/09/25 Javascript
[33:17]OG vs VGJ.T 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
安装Python的教程-Windows
2017/07/22 Python
对python append 与浅拷贝的实例讲解
2018/05/04 Python
python实现Virginia无密钥解密
2019/03/20 Python
python print出共轭复数的方法详解
2019/06/25 Python
如何使用Python多线程测试并发漏洞
2019/12/18 Python
浅谈TensorFlow之稀疏张量表示
2020/06/30 Python
python 6行代码制作月历生成器
2020/09/18 Python
美国从事品牌鞋类零售的连锁店:Famous Footwear
2016/08/25 全球购物
Whittard官方海外旗舰店:英国百年茶叶品牌
2018/02/22 全球购物
总监职责范文
2013/11/09 职场文书
重阳节登山活动方案
2014/02/03 职场文书
小学生常见病防治方案
2014/06/06 职场文书
党员干部四风问题整改措施思想汇报
2014/10/12 职场文书
师德先进个人材料
2014/12/20 职场文书
2015年七年级班主任工作总结
2015/05/21 职场文书
催款函范本大全
2015/06/24 职场文书
2015年度环卫处工作总结
2015/07/24 职场文书
公司出差管理制度范本
2015/08/05 职场文书