项目开始
Node后台项目常用到的包
添加express包(整个后台框架)
npm i express@4.17.1
// 导入 express 模块
const express = require('express')
// 创建 express 的服务器实例
const app = express()
// todo
// 调用 app.listen 方法,指定端口号并启动web服务器
app.listen(3000, () => {
console.log('Express server running at http://127.0.0.1:3000')
})
添加mysql包
npm i mysql@2.18.1
const mysql = require('mysql')
const db = mysql.createPool({
host: '127.0.0.1',
user: 'root',
password: 'root',
database: 'mydb'
})
module.exports = db
添加跨域包
npm i cors@2.8.5
// 导入并配置 cors 中间件
const cors = require('cors')
app.use(cors())
安装JWT的包:jsonwebtoken 用于生成JWT字符串 express-jwt 用于将JWT字符串解析还原成JSON对象
npm i jsonwebtoken
npm i express-jwt@5.3.3
// 引入jsonwebtoken和express-jwt
const jwt = require('jsonwebtoken')
const expreeJWT = require('express-jwt')
// 定义秘钥
const secretKey = 'Huangkg is very nice'
// 生成token
const tokenStr = jwt.sign({username:userinfo.username},secretKey,{expiresIn:'30s'})
// 将JWT字符串解析还原成JSON对象的中间件
app.use(expressJWT({secret:secretKey}).unless({path:[/^\/api\//]}))
添加“密码”加密包 bcryptjs
npm i bcryptjs@2.4.3
// 导入 bcryptjs 这个包
const bcrypt = require('bcryptjs')
// 调用 bcrypt.hashSync() 对密码进行加密
userInfo.password = bcrypt.hashSync(userInfo.password, 10)
安装表单验证
// 安装@escook/express-joi中间件,对表单进行验证
npm i @escook/express-joi
// 定义验证规则的包
npm i joi
// 导入验证表单数据的中间件
const expressJoi = require('@escook/express-joi')
// 导入需要的验证规则对象
const {
reg_login_schema
} = require("../schema/user")
// 注册
router.post('/reguser', expressJoi(reg_login_schema), user_handler.regUser)
// 登陆
router.post('/login', expressJoi(reg_login_schema), user_handler.login)
schema/user.js
const joi = require('joi')
/** string() 值必须是字符串
* alphanum() 值只能是包含 a-zA-Z0-9 的字符串
* min(length) 最小长度
* max(length) 最大长度
* required() 值是必填项,不能为 undefined
* pattern(正则表达式) 值必须符合正则表达式的规则
**/
const username = joi.string().alphanum().min(1).max(11).required()
const password = joi.string().pattern(/^[\S]{3,12}$/).required()
// 定义验证注册和登录表单数据的规则对象
exports.reg_login_schema = {
body: {
username,
password
}
}
1732

被折叠的 条评论
为什么被折叠?



