前言:第一次做完一个小项目,想来总结一下知识点和遇到的一些问题,可能写的有些凌乱。这次总结,想以项目知识点的顺序来做。
1.创建服务器
//引用express框架
const express = require(‘express’);
//创建网站服务器
const app = express();
2.数据库连接
//引入mongoose第三方模块
const mongoose = require('mongoose');
//连接数据库
mongoose.set('useCreateIndex', true);
mongoose.connect('mongodb://localhost/blog', {
useNewUrlParser: true ,useUnifiedTopology: true})
.then(()=>{
console.log('数据库连接成功');
}).catch(()=>{
console.log('数据库连接失败');})
3.创建路由
//引用express框架
const express = require('express');
const admin = express.Router();
4.mongoose创建集合
// 创建用户集合
// 引入mongoose第三方模块
const mongoose = require('mongoose');
// 导入bcrypt
const bcrypt = require('bcrypt');
// 引入joi模块
const Joi = require('joi');
// 创建用户集合规则
const userSchema = new mongoose.Schema({
username: {
type: String,
required: true,
minlength: 2,
maxlength: 20
},
email: {
type: String,
// 保证邮箱地址在插入数据库时不重复
unique: true,
required: true
},
password: {
type: String,
required: true
},
// admin 超级管理员
// normal 普通用户
role: {
type: String,
required: true
},
// 0 启用状态
// 1 禁用状态
state: {
type: Number,
default: 0
}
});
// 创建集合
const User = mongoose.model('User', userSchema);
5.在服务器端验证用户信息
用到的模块:
// 引入joi模块
const Joi = require('joi');
const validateUser = user => {
// 定义对象的验证规则
const schema = {
username: Joi.string().min(2).max(12).required().error(new Error('用户名不符合验证规则')),
email: Joi.string().email().required().error(new Error('邮箱格式不符合要求')),
password: Joi.string().regex(/^[a-zA-Z0-9]{
3,30}$/).required().error(new Error('密码格式不符合要求')),
role: Joi.string().valid('normal', 'admin').required().error(new Error('角色值非法')),
state: Joi.number().valid(0, 1).required().error(new Error('状态值非法'))
};
// 实施验证
return Joi.validate(user, schema);
}
6.为创建进数据库中的密码进行加密
// 导入bcrypt
const bcrypt = require('bcrypt');
async function createUser () {
const salt = await bcrypt.genSalt(10);