blog.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')
});
admin.post('/login', async(req, res) => {const { email, password } = req.body;if (email.trim().length == 0 || password.trim().length == 0)return res.status(400).render('admin/error', { msg: '地址或者邮件错误' });let user = await User.findOne({ email });if (user) {if (password == user.password) {res.send('成功了');} else {res.status(400).render('admin/error', { msg: '地址或者邮件错误' });}} else {res.status(400).render('admin/error', { msg: '地址或者邮件错误' });}})module.exports = admin;

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
}

login.art

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>用户登录</title><link rel="stylesheet" href="/admin/lib/bootstrap/css/bootstrap.min.css"><link rel="stylesheet" href="/admin/css/base.css">
</head><body><div class="login-body"><div class="login-container"><h4 class="title">黑马程序员 - 博客管理员登录</h4><div class="login"><form action="/admin/login" method="post" id="loginForm"><div class="form-group"><label>邮件</label><input name="email" type="email" class="form-control" placeholder="请输入邮件地址"></div><div class="form-group"><label>密码</label><input name="password" type="password" class="form-control" placeholder="请输入密码"></div><button type="submit" class="btn btn-primary">登录</button></form></div><div class="tips"></div></div></div><script src="/admin/lib/jquery/dist/jquery.min.js"></script><script src="/admin/lib/bootstrap/js/bootstrap.min.js"></script><script src="/admin/js/common.js"></script><script type="text/javascript">// 为表单添加提交事件$('#loginForm').on('submit', function () {// 获取到表单中用户输入的内容var result = serializeToJson($(this))// 如果用户没有输入邮件地址的话if (result.email.trim().length == 0) {alert('请输入邮件地址');// 阻止程序向下执行return false;}// 如果用户没有输入密码if (result.password.trim().length == 0) {alert('请输入密码')// 阻止程序向下执行return false;}});</script>
</body>
</html>

前端学习(1392):多人管理项目12加密相关推荐

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

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

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

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

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

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

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

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

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

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

  6. 前端学习(1388):多人管理项目8user登录

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

  7. 前端学习(1394):多人管理项目14多人加密使用

    users.js // 创建用户集合 // 引入mongoose第三方模块 const mongoose = require('mongoose'); // 导入bcrypt const bcrypt ...

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

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

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

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

最新文章

  1. python 正则表达式方法_Python正则表达式一: 基本使用方法
  2. php-cgi占用cpu资源过高的解决方法
  3. 我是如何用Worktile进行敏捷开发的
  4. 六年级上学期计算机上册教案,六年级上册数学全册教案
  5. Ansible相关工具介绍、实例演示
  6. java 调用.net webservice axis2_java利用axis2调用.net写的webservice,传递自定义的实体类参数...
  7. PyTorch基础(part2)
  8. opentrace在mysql中使用_采用OpenReplicator解析MySQL binlog
  9. Linux 命令之 chfn -- 修改用户信息
  10. HDU 4190 Distributing Ballot Boxes【二分答案】
  11. php中mysql数据库集群,MySQL集群
  12. java 多线程 最优_Java多线程与并发系列从0到1全部合集,强烈建议收藏!
  13. TokenInsight作为联盟伙伴加入CoinMarketCap的数据透明联盟(DATA) | TokenInsight
  14. ue4 离线渲染_UE4渲染引擎模块简介(2)
  15. 华为+android+root权限获取root,华为root权限获取的方法有哪些【图文】
  16. 因为计算机丢失vrender,3DMAX打开文件时显示缺少dll解决方案
  17. 思科Cisco AnyConnect 下载地址(windows、macos、iOS、Android、linux)
  18. 3ds Max 实验十二 材质的种类
  19. 新魔百盒UNT413-905L3B-当贝桌面完美线刷包-各项正常
  20. 计算机二级c语言停考,计算机等级考试调整Fortran等语言停考

热门文章

  1. 计算机应用基础教程作业脑图 车辆工程学院 冯大昕
  2. 20155320 第十一周课堂总结
  3. NQueens, NQueens2 N皇后问题,递归回溯
  4. SQLite数据库如何存储和读取二进制数据
  5. c语言枚举代替双switch,C语言 使用数组代替switch分支语句降低圈复杂度
  6. cronschedulebuilder 到时还没运行完_为什么我的软件编译时没问题,运行时却出错?...
  7. 【STC15库函数上手笔记】9、硬件SPI
  8. python对时间日期做格式化
  9. 发送附件时,防止文件名中的中文字符变成乱码
  10. ES6使用object的is()方法比较两个值