node 实现Token状态登录 及数据库增删改查
1.项目目录结构

2.启动入口文件代码index.js
const express = require('express')
const bodyParser = require('body-parser')
const cookieParser = require('cookie-parser')
const userRouter = require('./user')
const personRouter = require('./person')
const checkToken = require('./check_token')
const app = express()
app.use(cookieParser())
app.use(bodyParser.json())
app.use('/api',userRouter)
app.use('/api',checkToken,personRouter)
app.listen(9093, function() {
console.log('Node app start at port 9093')
});
3.mongoose连接数据库model.js
const mongoose = require('mongoose');
// 链接mongo 并且使用imooc这个集合
const DB_URL = 'mongodb://localhost:27017/demo';
mongoose.connect(DB_URL);
const models = {
user:{
'user':{type:String, 'require':true},
'pwd':{type:String, 'require':true},
'type':{'type':String, 'require':true},
//头像
'avatar':{'type':String},
// 个人简介或者职位简介
'desc':{'type':String},
// 职位名
'title':{'type':String},
// 如果你是boss 还有两个字段
'company':{'type':String},
'money':{'type':String}
},
person:{
//创建时间
date:{'type':String},
//联系人名字
name:{type:String},
//联系人年龄
age:{type:Number},
//联系人性别
sex:{'type':String},
//联系人地址
address:{'type':String}
}
};
for(let m in models){
mongoose.model(m, new mongoose.Schema(models[m]))
};
module.exports = {
getModel:function(name){
return mongoose.model(name)
}
};
4.登录逻辑处理user.js
const express = require('express')
const utils = require('utility')
const sd = require('silly-datetime')
const jwt = require('jsonwebtoken')
const Router = express.Router()
const model = require('./model')
const User = model.getModel('user')
const _filter = { 'pwd': 0, '__v': 0 }
const secret = 'zero'
Router.post('/loginRegister', function(req, res) {
const { user, pwd } = req.body
User.findOne({ user }, function(err, doc) {
if (doc) {
if (doc.pwd != md5Pwd(pwd)) {
return res.json({ code: 1, msg: '用户名或者密码错误' })
} else {
let token = jwt.sign(doc.toJSON(), secret, {
expiresIn: 60 * 60 //秒到期时间
});
let { _id, user } = doc
return res.json({ code: 0, data: { _id, user, token } })
}
} else {
const userModel = new User({ user, pwd: md5Pwd(pwd) })
userModel.save(function(e, d) {
if (e) {
return res.json({ code: 1, msg: '后端出错了' })
}
let token = jwt.sign(d.toJSON(), secret, {
expiresIn: 60 * 60 //秒到期时间
});
let { _id, user } = d
return res.json({ code: 0, data: { _id, user, token } })
})
}
})
})
function md5Pwd(pwd) {
const salt = '!@~#Zero389409258'
return utils.md5(utils.md5(pwd + salt))
}
module.exports = Router;
5.token验证中间件check_token.js
var jwt = require('jsonwebtoken')
const secret = 'zero'
module.exports = function(req, res, next) {
//检查post的信息或者url查询参数或者头信息
var token = req.body.token || req.query.token || req.headers['x-access-token']
// 解析 token
if (token) {
// 确认token
jwt.verify(token, secret, function(err, decoded) {
if (err) {
return res.json({ code: 1, msg: 'token信息错误或失效!' })
} else {
// 如果没问题就把解码后的信息保存到请求中,供后面的路由使用
req.api_user = decoded
next()
}
});
} else {
// 如果没有token,则返回错误
return res.status(403).send({
code: 1,
msg: '没有提供token!'
})
}
}
6.mongoose增删改查person.js
const express = require('express')
const utils = require('utility')
const sd = require('silly-datetime')
const jwt = require('jsonwebtoken')
const Router = express.Router()
const model = require('./model')
const Person = model.getModel('person')
const _filter = { 'pwd': 0, '__v': 0 }
Router.post('/personSave', function(req, res) {
const { name, sex, age, address, _id } = req.body
const body = req.body
let date = sd.format(new Date(), 'YYYY-MM-DD HH:mm')
const personModel = new Person({ name, sex, age, address, date })
if (_id == '') {
personModel.save(function(e, doc) {
if (e) {
return res.json({ code: 1, msg: '后端出错了' })
}
return res.json({ code: 0, data: { name, sex, age, address, _id } })
})
} else {
Person.findByIdAndUpdate(_id, { name, sex, age, address }, function(err, doc) {
const data = Object.assign({}, doc)
return res.json({ code: 0, data: data })
})
}
})
Router.post('/personRemove', function(req, res) {
const _id = req.body._id;
Person.findByIdAndRemove(_id, function(err, doc) {
return res.json({ code: 0, data: doc })
})
})
Router.get('/personList', function(req, res) {
Person.find({})
.skip(0)
.limit(10)
.sort({ '_id': -1 })
.exec(function(err, doc) {
Person.count({}, function(err, count) {
let data = {
count: count,
personDataList: doc
}
return res.json({ code: 0, data: data })
})
});
})
module.exports = Router;
项目运行需启动本地mongodb
完整项目具体demo贴上 github :https://github.com/zhuzeliang/node-vue-demo
node 实现Token状态登录 及数据库增删改查的更多相关文章
- node.js封装数据库增删改查
数据库增删改查的封装 小编不容易 const sql = { insert: function (Collection, insertData) { return new Promise((resol ...
- (转)SQLite数据库增删改查操作
原文:http://www.cnblogs.com/linjiqin/archive/2011/05/26/2059182.html SQLite数据库增删改查操作 一.使用嵌入式关系型SQLite数 ...
- Android SQLite 数据库 增删改查操作
Android SQLite 数据库 增删改查操作 转载▼ 一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库--SQLite,SQLite3支持NU ...
- MySQL数据库(增删改查语句)
MySQL数据库(增删改查语句)一.登录数据库:----> mysql -uroot -proot;(对应用户名和密码)二.SQL语句: 数据定义语言DDL 用来定义数据库.表.列,关 ...
- Asp.Net操作MySql数据库增删改查
Asp.Net操作MySql数据库增删改查,话不多说直接步入正题.git源码地址:https://git.oschina.net/gxiaopan/NetMySql.git 1.安装MySQL数据库 ...
- NX二次开发-NX访问SqlServer数据库(增删改查)C#版
版本:NX9+VS2012+SqlServer2008r2 以前我写过一个NX访问MySQL数据库(增删改查)的文章https://www.cnblogs.com/nxopen2018/p/12297 ...
- Yii2.0高级框架数据库增删改查的一些操作(转)
yii2.0框架是PHP开发的一个比较高效率的框架,集合了作者的大量心血,下面通过用户为例给大家详解yii2.0高级框架数据库增删改查的一些操作 --------------------------- ...
- 2. MongoDB基本操作 —— 用Mongo.exe操作数据库增删改查
一.开篇 传统的关系数据库一般由数据库(database).表(table).记录(record)三个层次概念组成,MongoDB是由数据库(database).集合(collection).文档对象 ...
- go——beego的数据库增删改查
一直都不理解使用go语言的时候,为什么还要自己去装beego,以为使用go便可以解决所有的问题,结果在朋友的点拨下,才意识到: go与beego的关系就好比是nodejs与thinkjs的关系,因此也 ...
随机推荐
- Android MaoZhuaWeiBo开发Service抓取个人信息-2
前面把基本的东西讲完了,之后就是数据的获取和解析显示出来了,那接下来我们就负责抓取数据的这块吧,首先我们须要 在清单文件中载入服务和活动 加入:. <activity android:name= ...
- 解决ubuntu中firefox浏览器总是提示找不到server的问题
这个情况在我机器上常常出现,并且时不时的给你出点问题.可是有些时候等一下就好了.或者把引擎换到百度的话它就又行得通了.. 被这个问题搞得非常烦.上网查了下说是防火墙啊之类的出问题.可是自己弄了后这个问 ...
- 【uoj35】后缀排序
后缀数组模板题 #include<algorithm> #include<cstdlib> #include<cstring> #include<cstdio ...
- npm安装以及命令行
安装visual studio的时候,安装Node.js会同时安装npm 查看版本 PS C:\Users\clu\Desktop> npm --version5.6.0 PS C:\Users ...
- android判断正在使用的网络类型 0.不知道网络类型;1、2G;2、3G;3、4g;4、wifi
判断正在使用的网络类型 0.不知道网络类型:1.2G:2.3G:3.4g:4.wifi /** Unknown network class. {@hide} */ public static fina ...
- bzoj 1782: [Usaco2010 Feb]slowdown 慢慢游【dfs序+线段树】
考虑每头牛到达之后的影响,u到达之后,从1到其子树内的点需要放慢的都多了一个,p为u子树内点的牛ans会加1 用线段树维护dfs序,每次修改子树区间,答案直接单点查询p即可 #include<i ...
- sql 索引详解
索引的重要性 数据库性能优化中索引绝对是一个重量级的因素,可以说,索引使用不当,其它优化措施将毫无意义. 聚簇索引(Clustered Index)和非聚簇索引 (Non- Clustered Ind ...
- 二分搜索 POJ 3258 River Hopscotch
题目传送门 /* 二分:搜索距离,判断时距离小于d的石头拿掉 */ #include <cstdio> #include <algorithm> #include <cs ...
- CF817C Really Big Numbers
思路: 二分. 实现: #include <iostream> #include <cstdio> using namespace std; typedef long long ...
- 微信小程序一些常见的坑
1.小程序都报wxss编译错误 解决方法: 在控制台输入openVendor() ,清除里面的wcsc wcsc.exe 然后重启工具 2.微信小程序wx:for警告 Now you can prov ...