|
| 1 | +const fs = require('fs') |
| 2 | +const path = require('path') |
| 3 | +const sha1 = require('sha1') |
1 | 4 | const express = require('express')
|
2 | 5 | const router = express.Router()
|
| 6 | + |
| 7 | +const UserModel = require('../models/users') |
3 | 8 | const checkNotLogin = require('../middlewares/check').checkNotLogin
|
4 | 9 |
|
5 | 10 | // GET /signup 注册页
|
6 | 11 | router.get('/', checkNotLogin, function (req, res, next) {
|
7 |
| - res.send('注册页') |
| 12 | + res.render('signup') |
8 | 13 | })
|
9 | 14 |
|
10 | 15 | // POST /signup 用户注册
|
11 | 16 | router.post('/', checkNotLogin, function (req, res, next) {
|
12 |
| - res.send('注册') |
| 17 | + const name = req.fields.name |
| 18 | + const gender = req.fields.gender |
| 19 | + const bio = req.fields.bio |
| 20 | + const avatar = req.files.avatar.path.split(path.sep).pop() |
| 21 | + let password = req.fields.password |
| 22 | + const repassword = req.fields.repassword |
| 23 | + |
| 24 | + // 校验参数 |
| 25 | + try { |
| 26 | + if (!(name.length >= 1 && name.length <= 10)) { |
| 27 | + throw new Error('名字请限制在 1-10 个字符') |
| 28 | + } |
| 29 | + if (['m', 'f', 'x'].indexOf(gender) === -1) { |
| 30 | + throw new Error('性别只能是 m、f 或 x') |
| 31 | + } |
| 32 | + if (!(bio.length >= 1 && bio.length <= 30)) { |
| 33 | + throw new Error('个人简介请限制在 1-30 个字符') |
| 34 | + } |
| 35 | + if (!req.files.avatar.name) { |
| 36 | + throw new Error('缺少头像') |
| 37 | + } |
| 38 | + if (password.length < 6) { |
| 39 | + throw new Error('密码至少 6 个字符') |
| 40 | + } |
| 41 | + if (password !== repassword) { |
| 42 | + throw new Error('两次输入密码不一致') |
| 43 | + } |
| 44 | + } catch (e) { |
| 45 | + // 注册失败,异步删除上传的头像 |
| 46 | + fs.unlink(req.files.avatar.path) |
| 47 | + req.flash('error', e.message) |
| 48 | + return res.redirect('/signup') |
| 49 | + } |
| 50 | + |
| 51 | + // 明文密码加密 |
| 52 | + password = sha1(password) |
| 53 | + |
| 54 | + // 待写入数据库的用户信息 |
| 55 | + let user = { |
| 56 | + name: name, |
| 57 | + password: password, |
| 58 | + gender: gender, |
| 59 | + bio: bio, |
| 60 | + avatar: avatar |
| 61 | + } |
| 62 | + // 用户信息写入数据库 |
| 63 | + UserModel.create(user) |
| 64 | + .then(function (result) { |
| 65 | + // 此 user 是插入 mongodb 后的值,包含 _id |
| 66 | + user = result.ops[0] |
| 67 | + // 删除密码这种敏感信息,将用户信息存入 session |
| 68 | + delete user.password |
| 69 | + req.session.user = user |
| 70 | + // 写入 flash |
| 71 | + req.flash('success', '注册成功') |
| 72 | + // 跳转到首页 |
| 73 | + res.redirect('/posts') |
| 74 | + }) |
| 75 | + .catch(function (e) { |
| 76 | + // 注册失败,异步删除上传的头像 |
| 77 | + fs.unlink(req.files.avatar.path) |
| 78 | + // 用户名被占用则跳回注册页,而不是错误页 |
| 79 | + if (e.message.match('duplicate key')) { |
| 80 | + req.flash('error', '用户名已被占用') |
| 81 | + return res.redirect('/signup') |
| 82 | + } |
| 83 | + next(e) |
| 84 | + }) |
13 | 85 | })
|
14 | 86 |
|
15 | 87 | module.exports = router
|
0 commit comments