在之前的版本(RC1)中,我使用界面IClientModelValidator
使用“ModelClientValidationEqualToRule
”类验证/比较密码和确认密码,如下所示
public IEnumerable<ModelClientValidationRule> GetClientValidationRules(ClientModelValidationContext context)
{
String strMsg = AccessLocalization.GetString(_resourceID);
var modelClientValidationEqualToRule = new ModelClientValidationEqualToRule(strMsg, _OtherPropertyName);
yield return modelClientValidationEqualToRule;
}
和jQuery
$.validator.addMethod("equalto",
function (value, element, parameters) {
return value;
});
$.validator.unobtrusive.adapters.add('equalto', [], function (options) {
options.rules.equalto = {};
options.messages['equalto'] = options.message;
});
但是,现在我正在使用.Net Core 1.0,其中此接口已完全更改,并且没有“ModelClientValidationEqualToRule
”类可用。
阅读documentation后,我发现验证将在数据属性的帮助下完成。所以,我已经实现了所需的字段属性,范围字段属性,电子邮件地址属性等。
但是,我不知道如何验证密码和确认密码?
对此有任何帮助表示赞赏!
答案 0 :(得分:5)
IClientModelValidator只有一种实现方法,此处显示的示例来自自定义EnforceTrueValidator,如果存在必需的注册协议,我会使用该条件有条件地强制检查注册页面上的复选框。此方法添加了所需的数据属性,以连接客户端不引人注意的验证。
public void AddValidation(ClientModelValidationContext context)
{
if (context == null)
{
throw new ArgumentNullException(nameof(context));
}
CheckForLocalizer(context);
var errorMessage = GetErrorMessage(context.ModelMetadata.GetDisplayName());
MergeAttribute(context.Attributes, "data-val", "true");
MergeAttribute(context.Attributes, "data-val-enforcetrue", errorMessage);
MergeAttribute(context.Attributes, "data-val-other", "#" + OtherProperty);
}
您可以看到完整的课程here,并且必须添加到自定义客户端验证页面的自定义js是here
在我的情况下,“other”属性只是一个布尔值,我用它来确定是否应该应用此验证器,因为我在多租户场景中使用它并且并非所有租户都可以强制执行注册协议,我将布尔值设置为true如果租户填写了注册协议