如果其中一个失败,是否有任何方法可以跳过在Ruleset中执行验证规则。
我的API端点有以下规则
param1,param2,param3
RuleSet =>
RuleFor(req => req.param1).NotEmpty().WithMessage("param1 is missing.");
RuleFor(req => req.param2).NotEmpty().WithMessage("param2 is missing.");
RuleFor(req => req.param3).NotEmpty().WithMessage("param3 is missing.");
RuleFor(req => req.param1).Must((req, param1) => IsValidRequest(req)).WithMessage("Invalid request.");
在我的IsValidRequest(req)中,我再次必须在进行自定义验证之前验证param1,param2,param3,即使上述规则失败,所有其他验证仍将继续尝试。
答案 0 :(得分:5)
默认情况下,FluentValidation使用Continue
级联模式在规则定义中调用验证器(即调用所有验证器)。在第一个验证器失败后,您应该使用StopOnFirstFailure
模式停止执行:
ValidatorOptions.CascadeMode = CascadeMode.StopOnFirstFailure;
请注意,这将全局设置StopOnFirstFailure
模式。如果要为特定验证器指定此模式,可以使用验证器类的属性:
public class RequestValidator : AbstractValidator<Request>
{
public RequestValidator()
{
CascadeMode = CascadeMode.StopOnFirstFailure;
RuleFor(req => req.param1)
.NotEmpty().WithMessage("param1 is missing.")
.Must((req, param1) => IsValidRequest(req)).WithMessage("Invalid request.");
RuleFor(req => req.param2).NotEmpty().WithMessage("param2 is missing.");
RuleFor(req => req.param3).NotEmpty().WithMessage("param3 is missing.");
}
}
在上面的示例中,如果Must
验证程序失败,则不会执行NotEmpty
验证程序。
如果您只想在所有三个参数都不为空时执行Must
验证器,那么When
是最佳选择:
When(req => !String.IsNullOrEmpty(req.param1)
&& !String.IsNullOrEmpty(req.param2)
&& !String.IsNullOrEmpty(req.param3), () => {
RuleFor(req => req.param1)
.Must((req, param1) => IsValidRequest(req)).WithMessage("Invalid request.");
});
您可以将前置条件检查移至单独的方法:
private bool AllParametersSpecified(Request req)
{
return !String.IsNullOrEmpty(req.param1)
&& !String.IsNullOrEmpty(req.param2)
&& !String.IsNullOrEmpty(req.param3);
}
条件更具可读性:
When(AllParametersSpecified, () => {
RuleFor(req => req.param1)
.Must((req, param1) => IsValidRequest(req)).WithMessage("Invalid request.");
});