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的关系,因此也 ...
随机推荐
- (转)C3P0配置
C3P0是一个开源的JDBC 连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展.目前使用它的开源项目有Hibernate,Spring等. sourceforge 下载: ...
- 7-74 JavaScript 事件
7-74 JavaScript 事件 学习要点 掌握常用的javaScript事件 基本概念 事件是一些特定动作发生时所发出的信号,JavaScript中的事件是可以被 JavaScript 侦测到的 ...
- 【Silverlight】Bing Maps学习系列(一):开发前的准备工作
[Silverlight]Bing Maps学习系列(一):开发前的准备工作 微软推出的Bing Maps地图引擎,对外开放了Silverlight和Ajax两种客户端API,同时微软针对全球地图还推 ...
- Codeforces Round #369 (Div. 2) 套题
A:模拟水题不说 #include <iostream> #include <string.h> #include <algorithm> #include < ...
- Java日期推迟计算、日期大小
/** * 日期推迟计算 * @param date * @param num * @return java.util.HashMap<java.lang.String,java.lang.St ...
- POJ2115 C-Loop
传送门 这道题是求解不定方程的一道好练习题. 题目描述的很诡异……还说什么k进制,其实就是要求一个数A,每次加C,问到B要加多少次,所有的数对2k取模. 也就是说我们能列出如下方程:A+xC ≡ B ...
- 5. extjs 中buttonAlign什么意思
转自:https://zhidao.baidu.com/question/1174901985976576339.html指定Panel中按钮的位置.可配置的值有'right', 'left' 和 ' ...
- Akka源码分析-Cluster-ClusterClient
ClusterClient可以与某个集群通信,而本身节点不必是集群的一部分.它只需要知道一个或多个节点的位置作为联系节点.它会跟ClusterReceptionist 建立连接,来跟集群中的特定节点发 ...
- java 读取word
读取word文件 import java.io.File; import java.io.FileInputStream; import java.io.InputStream; import org ...
- ASP.NET 知识点总结(六)
1.传入某个属性的set方法的隐含参数的名称是什么?value,它的类型和属性所声名的类型相同. 2.如何在C#中实现继承? 在类名后加上一个冒号,再加上基类的名称.3.C#支持多重继承么? 类之间不 ...