feat(user): 添加用户创建验证并更新相关功能
- 在 userController 中添加了用户创建时的输入验证,包括 account 和 password 的长度限制 - 更新了 createUser 函数,使用 express-validator 进行参数验证 - 修正了 app.js 中的 authenticateSession 方法名 - 更新了 package.json 和 package-lock.json 中的 express-validator 版本
This commit is contained in:
		
							parent
							
								
									87ea20acd0
								
							
						
					
					
						commit
						9dab2c0ae5
					
				
							
								
								
									
										2
									
								
								app.js
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								app.js
									
									
									
									
									
								
							| @ -53,7 +53,7 @@ startServer() | |||||||
| 
 | 
 | ||||||
| // app.use('/', loginUtils.aopMiddleware, indexRouter);
 | // app.use('/', loginUtils.aopMiddleware, indexRouter);
 | ||||||
| app.use('/', indexRouter) | app.use('/', indexRouter) | ||||||
| app.use('/user',loginUtil.authenticateSeesion, userRouter) | app.use('/user', loginUtil.authenticateSession, userRouter) | ||||||
| 
 | 
 | ||||||
| // catch 404 and forward to error handler
 | // catch 404 and forward to error handler
 | ||||||
| app.use(function (req, res, next) { | app.use(function (req, res, next) { | ||||||
|  | |||||||
| @ -1,3 +1,4 @@ | |||||||
|  | const { body, validationResult } = require('express-validator') | ||||||
| const userService = require('../services/userService') | const userService = require('../services/userService') | ||||||
| 
 | 
 | ||||||
| exports.getAllUsers = async (req, res) => { | exports.getAllUsers = async (req, res) => { | ||||||
| @ -9,11 +10,19 @@ exports.getAllUsers = async (req, res) => { | |||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| exports.createUser = async (req, res) => { | exports.createUser = [ | ||||||
|  |   body('account').isLength({ min: 3 }), | ||||||
|  |   body('password').isLength({ min: 6 }), | ||||||
|  |   async (req, res, next) => { | ||||||
|  |     const errors = validationResult(req) | ||||||
|  |     if (!errors.isEmpty()) { | ||||||
|  |       return res.status(400).json({ errors: errors.array() }) | ||||||
|  |     } | ||||||
|     try { |     try { | ||||||
|     const user = await userService.create_user(req.body) |       await userService.create_user(req.body) | ||||||
|     res.json(user) |       res.status(201).json({ message: 'User created successfully' }) | ||||||
|     } catch (err) { |     } catch (err) { | ||||||
|       res.status(500).json({ error: err.message }) |       res.status(500).json({ error: err.message }) | ||||||
|     } |     } | ||||||
| } |   } | ||||||
|  | ] | ||||||
|  | |||||||
							
								
								
									
										11
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										11
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @ -16,7 +16,7 @@ | |||||||
|         "express": "^4.19.2", |         "express": "^4.19.2", | ||||||
|         "express-async-handler": "^1.2.0", |         "express-async-handler": "^1.2.0", | ||||||
|         "express-session": "^1.18.0", |         "express-session": "^1.18.0", | ||||||
|         "express-validator": "^7.0.1", |         "express-validator": "^7.2.0", | ||||||
|         "http-errors": "~1.6.3", |         "http-errors": "~1.6.3", | ||||||
|         "jade": "^0.29.0", |         "jade": "^0.29.0", | ||||||
|         "mongoose": "^8.3.4", |         "mongoose": "^8.3.4", | ||||||
| @ -767,12 +767,13 @@ | |||||||
|       ] |       ] | ||||||
|     }, |     }, | ||||||
|     "node_modules/express-validator": { |     "node_modules/express-validator": { | ||||||
|       "version": "7.0.1", |       "version": "7.2.0", | ||||||
|       "resolved": "https://registry.npmjs.org/express-validator/-/express-validator-7.0.1.tgz", |       "resolved": "https://registry.npmmirror.com/express-validator/-/express-validator-7.2.0.tgz", | ||||||
|       "integrity": "sha512-oB+z9QOzQIE8FnlINqyIFA8eIckahC6qc8KtqLdLJcU3/phVyuhXH3bA4qzcrhme+1RYaCSwrq+TlZ/kAKIARA==", |       "integrity": "sha512-I2ByKD8panjtr8Y05l21Wph9xk7kk64UMyvJCl/fFM/3CTJq8isXYPLeKW/aZBCdb/LYNv63PwhY8khw8VWocA==", | ||||||
|  |       "license": "MIT", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "lodash": "^4.17.21", |         "lodash": "^4.17.21", | ||||||
|         "validator": "^13.9.0" |         "validator": "~13.12.0" | ||||||
|       }, |       }, | ||||||
|       "engines": { |       "engines": { | ||||||
|         "node": ">= 8.0.0" |         "node": ">= 8.0.0" | ||||||
|  | |||||||
| @ -15,7 +15,7 @@ | |||||||
|     "express": "^4.19.2", |     "express": "^4.19.2", | ||||||
|     "express-async-handler": "^1.2.0", |     "express-async-handler": "^1.2.0", | ||||||
|     "express-session": "^1.18.0", |     "express-session": "^1.18.0", | ||||||
|     "express-validator": "^7.0.1", |     "express-validator": "^7.2.0", | ||||||
|     "http-errors": "~1.6.3", |     "http-errors": "~1.6.3", | ||||||
|     "jade": "^0.29.0", |     "jade": "^0.29.0", | ||||||
|     "mongoose": "^8.3.4", |     "mongoose": "^8.3.4", | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 LingandRX
						LingandRX