Mic*_* B. 8 passwords validation compare asp.net-mvc-3
我正在使用MVC3,我希望在同一页面上有LogIn表单和Register表单.为此,我构建了LogInRegisterViewModel,如下所示:
public class LogInRegisterViewModel
{
public LogInViewModel LogIn { get; set; }
public RegisterViewModel Register { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
它给了我想要的东西(在同一个屏幕上有两个表格)并将数据发布到正确的控制器并返回并显示表单错误(如果有的话).我唯一的问题是CompareAttribute,我在RegisterViewModel中有ConfirmPassword属性:
public class RegisterViewModel
{
[Required]
[Display(Name = "Friendly user name")]
public string UserName { get; set; }
[Required]
[Display(Name = "E-mail address")]
public string Email { get; set; }
[Required]
[DataType(DataType.Password)]
[Display(Name = "Password")]
[StringLength(16, ErrorMessage = "The {0} must be at least {2} characters long.", MinimumLength = 6)]
public string Password { get; set; }
[DataType(DataType.Password)]
[Display(Name = "Confirm password")]
[Compare("Password", ErrorMessage = "Passwords do not match.")]
public string ConfirmPassword { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
客户端的密码永远不会相等(〜我总是得到一个验证错误,比较消息告诉我它们不相等),即使它们是(我很确定).浏览器中的HTML是:
<div class="editor-label">
<label for="Register_Password">Password</label>
</div>
<div class="editor-field">
<input class="valid" data-val="true" data-val-length="The Password must be at least 6 characters long." data-val-length-max="16" data-val-length-min="6" data-val-required="The Password field is required." id="Register_Password" name="Register.Password" type="password">
<span class="field-validation-valid" data-valmsg-for="Register.Password" data-valmsg-replace="true"></span>
</div>
<div class="editor-label">
<label for="Register_ConfirmPassword">Confirm password</label>
</div>
<div class="editor-field">
<input class="input-validation-error" data-val="true" data-val-equalto="Passwords do not match." data-val-equalto-other="*.Password" id="Register_ConfirmPassword" name="Register.ConfirmPassword" type="password">
<span class="field-validation-error" data-valmsg-for="Register.ConfirmPassword" data-valmsg-replace="true"><span class="" generated="true" for="Register_ConfirmPassword">Passwords do not match.</span></span>
</div>
Run Code Online (Sandbox Code Playgroud)
我觉得这是关于这个属性的全部:data-val-equalto-other ="*.密码"
当我直接使用RegisterViewModel时,CompareAttribute工作正常.以前有人进过这个吗?这是一个错误还是我做错了什么?如何比较我的情况下的工作?
nem*_*esv 15
它应该与[Compare("Password", ErrorMessage = "Passwords do not match.")]属性一起使用,但似乎这是jquery.validate.unobtrusive.js文件中的一个错误.问题出在这段代码中:
adapters.add("equalto", ["other"], function (options) {
var prefix = getModelPrefix(options.element.name),
other = options.params.other,
fullOtherName = appendModelPrefix(other, prefix),
element = $(options.form).find(":input[name=" + fullOtherName + "]")[0];
setValidationValues(options, "equalTo", element);
});
Run Code Online (Sandbox Code Playgroud)
所以它试图用JQuery find方法找到另一个控件.但是"." 如此SO问题dot中所述,fullOtherName变量(在您的情况下它将包含:)中不会转义字符.这就是为什么它只能直接使用RegisterViewModel的原因,因为名称中没有点."Register.Password"
要修复它,您需要在appendModelPrefix函数中添加一行:
//original
function appendModelPrefix(value, prefix) {
if (value.indexOf("*.") === 0) {
value = value.replace("*.", prefix);
}
return value;
}
//fixed
function appendModelPrefix(value, prefix) {
if (value.indexOf("*.") === 0) {
value = value.replace("*.", prefix);
}
value = value.split('.').join('\\.');
return value;
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4779 次 |
| 最近记录: |