MVC 5远程验证

前端之家收集整理的这篇文章主要介绍了MVC 5远程验证前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在提交表单之前,我需要验证用户的输入字段值.

我已经在我的自定义控制器中创建了一个动作,并用它来装饰了它:

动作名称:CheckValue
控制器名称:验证

  1. [Remote("CheckValue","Validate"),ErrorMessage="Value is not valid"]
  2. public string Value { get; set; }

问题是当我按提交,表单正在提交,然后如果用户输入的值无效,则显示“无效”消息.

如何验证用户输入的值,如果值无效,则阻止提交表单,并显示错误消息?

如果我尝试使用JavaScript检查表单是否有效$(“#formId”).valid()返回true,这意味着无论该值的状态是什么(有效还是无效)表单都是有效的.

另一方面,如果我使用[必需]属性来装饰另一个字段,则表单不会被提交,并且为该字段显示所需的错误.但是,远程验证字段的场景后面不会发生验证.

解决方法

远程验证在MVC中的完整解决方案.它将检查数据库中的电子邮件,然后检查数据库中是否存在,然后显示错误

Email already exists

帐号控制器动作

  1. [AllowAnonymous]
  2. [HttpPost]
  3. public ActionResult CheckExistingEmail(string Email)
  4. {
  5. try
  6. {
  7. return Json(!IsEmailExists(Email));
  8. }
  9. catch (Exception ex)
  10. {
  11. return Json(false);
  12. }
  13. }
  14.  
  15. private bool IsEmailExists(string email)
  16. => UserManager.FindByEmail(email) != null;

2.添加模型验证

  1. [required]
  2. [MaxLength(50)]
  3. [EmailAddress(ErrorMessage = "Invalid Email Address")]
  4. [System.Web.Mvc.Remote("CheckExistingEmail","Account",HttpMethod = "POST",ErrorMessage = "Email already exists")]
  5. public string Email { get; set; }

3.添加脚本

  1. <script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
  2. <script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script>

它可能会帮助你.谢谢

猜你在找的asp.Net相关文章