// 引入用户集合的构造函数
const { User, validateUser } = require('../../model/user');
// 引入加密模块
const bcrypt = require('bcryptjs');module.exports = async(req, res, next) => {try {await validateUser(req.body)} catch (e) {// 验证没有通过// e.message// 重定向回用户添加页面// return res.redirect(`/admin/user-edit?message=${e.message}`);// JSON.stringify() 将对象数据类型转换为字符串数据类型return next(JSON.stringify({ path: '/admin/user-edit', message: e.message }))}// 根据邮箱地址查询用户是否存在let user = await User.findOne({ email: req.body.email });// 如果用户已经存在 邮箱地址已经被别人占用if (user) {// 重定向回用户添加页面// return res.redirect(`/admin/user-edit?message=邮箱地址已经被占用`);return next(JSON.stringify({ path: '/admin/user-edit', message: '邮箱地址已经被占用' }))}// 对密码进行加密处理// 生成随机字符串const salt = await bcrypt.genSalt(10);// 加密const password = await bcrypt.hash(req.body.password, salt);// 替换密码req.body.password = password;// 将用户信息添加到数据库中await User.create(req.body);// 将页面重定向到用户列表页面res.redirect('/admin/user');
}