跟着官网学ASP.NET Core 6.0之请求参数模型验证
前面,我们学习了模型绑定,这一节,我们继续跟着官网来学习一下模型验证,一般情况下,我们需要对传入的参数进行校验,常规操作一般是通过if
来对每一个需要校验的参数进行判断,在使用模型之后,我们便可以借助ASP.NET Core
提供的特性来简化我们这繁琐、重复的判断过程
我们继续前面的例子,一个ModelBindVo
类型
1 | public class ModelBindVo |
一个Get
请求方法
1 | [HttpGet] |
如果我们访问/api/ModelBind?Name=000&Age=90
,会在日志中打印出000,90,如果我们是参数不是模型中的类型,如/api/ModelBind?Name=000&Age=happy
,那么,服务端会直接返回400
,并有这样的提示
这样的错误提示,肯定是要不得滴,另外,如果我们访问/api/ModelBind?Name=000
,那么Age
便会默认为0,如果,我们业务要求必须是年龄在18-60岁才能处理,其他情况便返回错误,这种怎么处理呢?一般是在程序里面写if
是吧,用模型校验就不一样了,我们只需要这样
1 | public class ModelBindVo |
此时我们在访问接口/api/ModelBind?Name=000
或者api/ModelBind?Name=000&Age=9
,
作为开发人员来说,这样的提示肯定是看得懂的,那么,用户怎么看得懂呢?莫慌,我们可以在Range
特性中指定ErrorMessage
的错误提示内容
1 | public class ModelBindVo |
除了Range
特性外,ASP.NET Core
还为我们提供了其他验证特性,如:
- [Compare]:验证模型中的两个属性是否匹配。
- [EmailAddress]:验证属性是否具有电子邮件格式。
- [Phone]:验证属性是否具有电话号码格式。
- [Range]:验证属性值是否位于指定范围内。
- [RegularExpression]:验证 属性值是否与指定的正则表达式匹配。
- [Required]:验证字段是否不为 null。
- [StringLength]:验证字符串属性值是否不超过指定的长度限制。
- [Url]:验证属性是否是URL格式。
其他的特性,可以在System.ComponentModel.DataAnnotations
命名空间下找到
当然,可能这些特性依然满足不了你的需要,那这就需要自定义校验特性。这有两种方式,第一种就是创建继承ValidationAttribute
自定义验证特性类来重写IsValid
方法,用法和内置特性一致;第二种便让模型继承IValidatableObject
接口,我们来试试第二种
1 | public class ModelBindVo: IValidatableObject |
这时,我们访问api/ModelBind?Name=000&Age=30
,便会进入到我们自定义的逻辑中
ASP.NET Core还提供参数校验失败次数,今天就先不了解了,有兴趣的可以去官网了解一下,明天,我们继续学学
设置 ASP.NET Core Web API 中响应数据的格式
跟着官网学ASP.NET Core 6.0之请求参数模型验证