日常作业中免不了频繁处理 GET/POST 的入参,你当然可以每个 action 中都重复地去做这些事情,
但这些通用的逻辑可通过抽取到插件或服务中,避免代码冗余和重复劳动。 egg-validationEgg.js 中可通过 egg-validation 插件来减少这部分的工作量。通过该插件,上面大部分工作可转成简单的配置。 安装插件$ yarn add egg-validate 配置插件启用: config/plugin.ts const plugin: EggPlugin = { // ... validate: { enable: true, package: 'egg-validate', }, // ... }; export default plugin; 配置插件: config/config.default.ts export default (appInfo: EggAppInfo) => { const config = {} as PowerPartial<EggAppConfig>; // ... config.validate = { convert: true, widelyUndefined:true }; // ... }; 其配置项为 node-modules/parameter 的所有可用配置项,因为该插件其实就是后者的 Egg.js 封装。
使用插件在 比如接收一个名为 app/controller/home.ts const errors = this.app.validator.validate({ name: 'string' }, this.request.body); if (errors) { this.ctx.body = errors; } 验证规则
const rules = { param1: 'string', // 必填的字符串入参 param2: 'string?', // 可选的字符串入参 param3: { type: 'int', // 整形入参 required: false, // 该入参可选 min: 0, // 该入参的最小值 max: 10, // 该入参的最大值 }, }; 规则默认入参是必填的,对于可选的入参,可通过在类型后加问号,与 TypeScript 类似,也可以显式指定 预设可用的参数类型参见 parameter。 针对参数的规则配置,根据参数的类型,有不同的配置顶,比如对于数字类型,可配置其最大最小值;对于枚举,可定义其候选值,一旦入参不在这些值之内,便验证不通过。每种类型可用的配置项参见 parameter。 自定义验证规则如果上面文档中预设的这些类型无法满足需求,可通过 其中 checker.call(self, rule, obj[key], obj); 比如增加一种类型为 app.ts export default (app) => { app.validator.addRule('jsonString', (_rule, value) => { try { JSON.parse(value); } catch (err) { return 'must be json string'; } }); }; 示例代码一个可本地运行调试,配合了预设的验证规则及自定义的规则的示例,完整代码可在 GitHub 找到。 结论写了过多的重复的代码后,比如这种入参的校验,就应该想想如何优雅地来处理这些重复的工作,无论是自己造*,还是找*。入参的校验如此之常见,进而,甚至可以去追求一套前后台通用的校验逻辑,将浏览器端的 JavaScript 与 Node.js 的逻辑进行统一。 相关资源 |