npm egg-validate-plus –save

13.1 开启插件

1
2
3
4
5
// config/plugin.{env}.js
exports.validatePlus = {
enable: true,
package: 'egg-validate-plus',
};

13.2 配置插件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
// 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: '参数错误',
};
}
}
};

13.3 使用插件

13.3.1 传入字符串

1
2
// app/controller/xx.js
const { query } = this.ctx.request;

拿到验证结果

1
const validateResult = await this.ctx.validate('user.login', query)

验证不通过时,阻止后面的代码执行

1
if (!validateResult) return

> 注意:不要带上 rules

13.3.2 直接传入验证规则对象

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
// 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