标签:const err 后端 res 验证 表单 规则 Nodejs joi
Nodejs后端:验证表单数据
使用 joi
第三方包,joi官方文档。
1. 安装 相关包
npm install joi
npm install @escook/express-joi
2. 定义验证规则模块
// 导入定义验证规则包
const joi = require('joi')
// 定义用户名和密码的验证规则
const username = joi.string().alphanum().min(3).max(16).required()
const password = joi.string().pattern(new RegExp('^[a-zA-Z0-9]{6,12}$')).required()
// 定义登录注册表单规则对象
exports.regLoginSchema = {
body: {
username,
password
}
}
3. 使用验证规则模块
需要使用验证规则的路由模块中:
// 导入数据验证中间件
const expressJoi = require('@escook/express-joi')
// 导入需要验证的规则对象
const { regLoginSchema } = require('../schema/user')
// 应用
router.post('/resgiter', expressJoi(regLoginSchema), user_handle.resgiter)
入口文件 app.js
中:
// 定义错误级别中间件
app.use((err, req, res, next) => {
if (err instanceof joi.ValidationError) {
// 验证失败报错
return res.cc(err) // res.cc 为封装的一个函数,等价于res.send({ status: 1, message: err.message })
}
// 未知错误
res.cc(err)
})
标签:const,err,后端,res,验证,表单,规则,Nodejs,joi 来源: https://www.cnblogs.com/wjy00/p/15925368.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。