因此,根据Gu,当控制器验证其模型(即在IValidatableObject.Validate()
之前)时应调用ModelState.IsValid
,但是仅仅使模型实现IValidatableObject
似乎不起作用,因为Validate(..)
不会被调用。
有人知道我是否还需要整理一下才能使它工作?
编辑:
这是要求的代码。
public class LoginModel : IValidatableObject
{
[Required]
[Description("Email Address")]
public string Email { get; set; }
[Required]
[Description("Password")]
[DataType(DataType.Password)]
public string Password { get; set; }
[DisplayName("Remember Me")]
public bool RememberMe { get; set; }
public int UserPk { get; set; }
public IEnumerable<ValidationResult> Validate(ValidationContext validationContext)
{
var result = DataContext.Fetch( db => {
var user = db.Users.FirstOrDefault(u => u.Email == Email);
if (user == null) return new ValidationResult("That email address doesn't exist.");
if (user.Password != User.CreateHash(Password, user.Salt)) return new ValidationResult("The password supplied is incorrect.");
UserPk = user.UserPk;
return null;
});
return new List<ValidationResult>(){ result };
}
}
那个行动。 (我在控制器上没有做任何特别的事情...)
[HttpPost]
public ActionResult Login(LoginModel model)
{
if (ModelState.IsValid)
{
FormsAuthentication.SetAuthCookie(model.Email, model.RememberMe);
return Redirect(Request.UrlReferrer.AbsolutePath);
}
if (ControllerContext.IsChildAction || Request.IsAjaxRequest())
return View("LoginForm", model);
return View(model);
}
我在
LoginModel.Validate()
的第一行上设置了一个断点,它似乎没有被击中。 最佳答案
除了将其添加到您要验证的模型外,没有什么比其他的要多了。这是验证的示例
public class User : IValidatableObject {
public Int32 UserID { get; set; }
public string Name { get; set; }
public IEnumerable<ValidationResult> Validate(ValidationContext validationContext) {
//do your validation
return new List<ValidationResult>();
}
}
您的控制器将使用此模型
public ActionResult Edit(User user) {
if (ModelState.IsValid) {
}
}
希望这可以帮助。其他要求是.net 4和数据注释-对于ivalidatableobject,您显然需要jsut。发布任何问题,我们将查看是否无法解决问题,例如发布模型和控制器...您可能会遗漏一些东西。
关于data-annotations - MVC3中的ModelState.IsValid与IValidateableObject,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/3744408/