C#自定义模型验证主要通过DataAnnotations特性与IValidatableObject接口配合实现:前者用于字段级简单规则(如非空、长度、格式),后者处理跨字段及业务逻辑强相关的复合校验(如时间顺序、密码一致性、服务依赖验证)。

在 C# 中实现自定义模型验证,主要靠 DataAnnotations 特性 + 实现 IValidatableObject 接口两种方式配合使用。前者适合字段级简单规则(如非空、长度、格式),后者用于跨字段、业务逻辑强相关的复合校验(比如“结束时间不能早于开始时间”)。
用 DataAnnotations 做基础字段验证
这是最常用、最直观的方式。给模型属性打上内置特性,框架(如 ASP.NET Core MVC、Entity Framework)会自动触发验证。
-
[Required]:标记必填项,支持自定义错误消息:
[Required(ErrorMessage = "用户名不能为空")] - [StringLength(50, MinimumLength = 2)]:限制字符串长度范围
- [EmailAddress]、[Phone]、[Range(18, 65)]:语义化验证,开箱即用
- 自定义特性需继承
ValidationAttribute,重写IsValid方法(支持服务注入时建议用IValidationAttributeAdapterProvider配合)
用 IValidatableObject 做跨字段/业务级验证
当验证逻辑涉及多个属性、需要访问外部服务或执行复杂判断时,让模型实现 IValidatableObject 接口更合适。它提供一个 Validate 方法,在所有字段级验证通过后被调用。
- 实现方式:在模型类中添加
public IEnumerable<validationresult> Validate(ValidationContext validationContext)</validationresult> - 返回
ValidationResult.Success表示通过;否则用new ValidationResult("错误信息", new[] { "关联属性名" })返回失败项 - 例如:检查
StartDate和EndDate是否合法:
if (EndDate yield return new ValidationResult("结束时间不能早于开始时间", new[] { nameof(EndDate) }); - 注意:该方法不会自动触发字段级验证,它只补充校验——字段级失败时,
Validate通常不执行(取决于具体上下文,如 MVC 默认跳过)
两者结合使用的典型场景
实际开发中,推荐分层验证:用 DataAnnotations 拦住明显非法输入(空值、超长、格式错),再用 IValidatableObject 处理依赖关系和业务约束。
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~