// config/plugin.{env}.js
exports.validatePlus = {
enable: true,
package: 'egg-validate-plus',
};
// config/config.{env}.js
config.validatePlus = {
resolveError(ctx, errors) {
if (errors.length) {
ctx.type = 'json';
ctx.status = 400;
ctx.body = {
code: 400,
error: errors,
message: '参数错误',
};
}
}
};
|- MY-PROJECT
|- app
|- controller
|- user.js
|- post.js
|- rules
|- user
|- login.js [用户登录参数校验规则]
|- post
|- add.js [创建 post 参数校验规则]
|- config
|- config.default.js
|- plugin.js
|- package.json
|- README.md
// app/controller/xx.js
const { query } = this.ctx.request;
// 拿到验证结果
const validateResult = await this.ctx.validate('user.login', query)
// 验证不通过时,阻止后面的代码执行
if (!validateResult) return
注意:不要带上 rules
// app/controller/xx.js
// 直接引入 rules 文件下的验证规则,也可以是自己写的验证规则对象
const rule = this.app.rules.user.login
// 数据格式
// const rule = {
// id: [
// { required: true },
// { type: 'number', message: 'id 必须为数字 }
// ],
// password: [
// { required: true },
// { type: 'string', message: 'password 必须为字符串 }
// ]
// }
// 从客户端传入的参数
const { query } = this.ctx.request;
// 数据格式:
// query = {
// username: 123456,
// password: 'abcdefg'
// }
// 拿到验证结果
const validateResult = await this.ctx.validate(rule, query)
// 验证不通过时,阻止后面的代码执行
if (!validateResult) return
- 为什么要自己造轮子?
其实 egg 官方有一个 egg-validate 插件,非常的优秀。但是我觉得有几个不满意的地方:
- 不能使用自定义错误提示
- 类型校验兼容性差
- 非必填校验兼容性差
- 提供哪些更好的体验?
- 使用自定义错误提示
- 提供更多的类型校验
- 兼容更多非必填校验场景
egg-validate-plus 版本 | egg 1.x |
---|---|
1.x | 😁 |
0.x | ❌ |
- async-validator 目前大部分的校验规则插件都使用了 async-validator,包括前端的表单验证,egg-validate-plus 也不例外,感谢作者 yiminghe
请到 config/config.default.js 查看详细配置项说明。