一、概述
改变 ASP.NET Core WEB API 模型验证的默认行为。
二、问题
ApiControllerAttribure 特性通常结合 ControllerBase 来为控制器启用特定于 REST 行为。 通过 ControllerBase 可使用 NotFound 和 File 等方法。
它其中一个作用是自动 HTTP 400 响应。即验证错误会自动触发 HTTP 400 响应。 操作中不需要以下代码:
1 | if (!ModelState.IsValid) |
如果要改变这种行为,比如希望以 HTTP 200 响应,则有如下解决方案 。
三、解决方案
1、第一步
当 SuppressModelStateInvalidFilter 属性设置为 true 时,会禁用默认行为。 将以下代码添加至 Startup.ConfigureServices 中的 services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1); 后:
1 | // File: Startup.cs Method: ConfigureServices |
2、解决方案1: 在 Action 开头进行验证
1 | // File: XXXController.cs Method: XXXAction |
3 、解决方案2:自定义 ActionFilterAttribure
1 | // File: ModelValidaionActionFilterAttribute.cs |
ModelValidaionActionFilterAttribute 可在 Controller 或 Action 上使用;也可以做一个继承于 ControllerBase 的类,在其上使用该 Attribute,而其他 Controller 继承与该类;也可以全局注册 ModelValidaionActionFilterAttribute :
1 | // File: Startup.cs Method: ConfigureServicess |
4、解决方案3:使用 InvalidModelStateResponseFactory
不用再将 SuppressModelStateInvalidFilter 设置为 true,不再使用 ModelValidaionActionFilterAttribute, 也无需在 Action 中判断 ModelState.IsValid。
1 | // File: Startup.cs Method: ConfigureServices |
四、其他
不太重要的优化。模型验证时如果发生错误,将继续验证字段,直至达到错误数上限(默认为 200 个)。 通过向 Startup.cs 文件中的 ConfigureServices 方法插入以下代码,可配置该数字:
1 | // File: Startup.cs Method: ConfigureServicess |