在ASP Net Core 3.1中,可以通过自定义验证特性来对请求的参数进行合法性校验。但是,有时候需要同时对多个参数进行验证,并要求这些验证条件之间都成立才能通过验证。
例如,需要验证一个注册用户提交的表单,要求其中的用户名不能重复,密码必须包含数字和字母,且长度不能小于8个字符。这时候就需要对这三个条件进行组合验证,即只有这三个条件全部成立时,才能通过验证。
以下是实现组合验证的示例代码:
public class CustomValidationAttribute : ValidationAttribute
{
public string Username { get; set; }
public bool IncludeDigit { get; set; }
public bool IncludeLetter { get; set; }
public int MinLength { get; set; }
protected override ValidationResult IsValid(object value, ValidationContext validationContext)
{
// 验证用户名是否重复,返回错误信息或空
var dbContext = validationContext.GetService(typeof(AppDbContext)) as AppDbContext;
if (dbContext.Users.Any(u => u.Username == Username))
{
return new ValidationResult($"{Username}已存在。");
}
// 验证密码是否包含数字和字母,长度是否>=MinLength
var password = value?.ToString() ?? "";
bool hasDigit = IncludeDigit ? password.Any(c => char.IsDigit(c)) : true;
bool hasLetter = IncludeLetter ? password.Any(c => char.IsLetter(c)) : true;
bool hasValidLength = password.Length >= MinLength;
if (!hasDigit || !hasLetter || !hasValidLength)
{
return new ValidationResult($"密码不符合要求。");
}
// 验证通过
return ValidationResult.Success;
}
}
public class RegisterUserModel
{
[CustomValidation(Username = "admin", IncludeDigit = true, IncludeLetter = true, MinLength = 8)]
public string Password { get; set; }
}
在上面的代码中,我们定义