blog.js

const express = require('express');
//创建网站服务器
const app = express();
//开放静态资源文件
const path = require('path');
require('./model/connect')//告诉express框架模板所在的位置
app.set('views', path.join(__dirname, 'views'));
//告诉express框架模板的后缀是什么
app.set('view engine', 'art');
//当渲染后缀为art的时候 搜索引擎是什么
app.engine('art', require('express-art-template'))app.use(express.static(path.join(__dirname, 'public')));
//引入路由模块const home = require('./homegeyao');
const admin = require('./admingeyao');app.use('/home', home);
app.use('/admin', admin);
app.listen(3000);console.log('服务器启动成功');

admingeyao.js

//管理页面
//展示页面
const express = require('express');const admin = express.Router();admin.get('/login', (req, res) => {res.render('admin/login')
});
admin.get('/user', (req, res) => {res.render('admin/user')
});module.exports = admin;

homegeyao.js

//展示页面
const express = require('express');const home = express.Router();home.get('/', (req, res) => {res.send('欢迎来到博客首页');
});module.exports = home;

connect.js

// 引入mongoose第三方模块
const mongoose = require('mongoose');
// 连接数据库
mongoose.connect('mongodb://localhost/blog', {useNewUrlParser: true }).then(() => console.log('数据库连接成功')).catch(() => console.log('数据库连接失败'))

user.js

// 创建用户集合
// 引入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);async function createUser () {const salt = await bcrypt.genSalt(10);const pass = await bcrypt.hash('123456', salt);const user = await User.create({username: 'iteheima',email: 'itheima@itcast.cn',password: pass,role: 'admin',state: 0});
}// createUser();// 验证用户信息
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);
}// 将用户集合做为模块成员进行导出
module.exports = {User,validateUser
}

前端学习(1388):多人管理项目8user登录相关推荐

  1. 前端学习(1389):多人管理项目9登录功能具体实现

    blog.js const express = require('express'); //创建网站服务器 const app = express(); //开放静态资源文件 const path = ...

  2. 前端学习(1387):多人管理项目7登录 数据库连接

    blog.js const express = require('express'); //创建网站服务器 const app = express(); //开放静态资源文件 const path = ...

  3. GitHub 上值得前端学习的数据结构与算法项目

    Hello,大家好,我是你们的 前端章鱼猫. 简介 前端章鱼猫从 2016 年加入 GitHub,到现在的 2020 年,快整整 5 个年头了. 相信很多人都没有逛 GitHub 的习惯,因此总会有开 ...

  4. 前端学习(1393):多人管理项目13加密实现

    blog.js //管理页面 //展示页面 const express = require('express');const admin = express.Router();admin.get('/ ...

  5. 前端学习(1392):多人管理项目12加密

    blog.js //管理页面 //展示页面 const express = require('express');const admin = express.Router();admin.get('/ ...

  6. 前端学习(1391):多人管理项目11邮箱地址查询信息

    blog.js //管理页面 //展示页面 const express = require('express');const admin = express.Router();admin.get('/ ...

  7. 前端学习(1390):多人管理项目10服务器认证

    blog.js const express = require('express'); //创建网站服务器 const app = express(); //开放静态资源文件 const path = ...

  8. 前端学习(1386):多人管理项目6骨架

    blog.js const express = require('express'); //创建网站服务器 const app = express(); //开放静态资源文件 const path = ...

  9. 前端学习(1385):多人管理项目5抽离

    blog.js const express = require('express'); //创建网站服务器 const app = express(); //开放静态资源文件 const path = ...

最新文章

  1. Sharepoint 2010 Powershell去增加 上传文件类型
  2. C语言: 函数调用的开销
  3. 关于 spring MVC 配置自动扫描中 use-default-filters 属性
  4. 列主消元法解非奇异线性方程组的MATLAB程序
  5. jQuery 表单验证插件 jQuery Validation Engine 使用
  6. 在 Oracle 中使用正则表达式
  7. 循环结构程序设计学习心得
  8. C4D本来很简单(新手入门学习方法+C4D工作流程)
  9. Hadoop与MPP
  10. win10驱动开发16——派遣函数(直接方式读操作)
  11. “荣光医院”急救中心 73 问答
  12. springboot feign too many bytes written executing
  13. Windows Azure实战pdf
  14. tf.extract_image_patches以及pytorch的extract_patches
  15. Jane Austen谈Python:文学与技术的交集
  16. 字符串最长不重复子串 java_最长不重复子串问题
  17. 对“管道”的进一步理解
  18. android radioButton 改变圆圈大小
  19. 二十三.基于机器学习的恶意请求识别及安全领域中的机器学习
  20. JAVA面试以及新人入职分享

热门文章

  1. 显示和快速隐藏Mac桌面所有图标
  2. 搭建自己的base.js(2)-其他事件方法
  3. CListCtrl控件
  4. nginx集群_windows环境下搭建简单Nginx+Tomcat集群
  5. 王道操作系统考研笔记——1.1.1 操作系统的概念、功能和目标
  6. php js动态显示系统时间,PHP+JS动态显示服务器时间
  7. Exynos4412 Uboot 移植(一)—— Uboot 编译流程分析
  8. windows隐藏python运行时的终端
  9. 系统没有远程桌面,如何安装远程桌面
  10. 红黑树实现——STL中的map