大多數的開發者,可能會遇到這樣的狀況:當咱們在建立用戶以前,有必要去檢查是否數據庫中已經存在相同名字的用戶。換句話說就是,咱們要確保程序中,只有一個惟一的用戶名,不能有重複的。相信大多數人都有不一樣的解決方法,可是ASP.NET MVC中,爲咱們提供了一個特性,就是Remote Validation,用它能夠解決相似這樣的問題。html
Remote Validation調用了一個Ajax請求,能夠是GET或者POST方式,接着調用方法,這個方法,至少要有一個參數,而且方法的返回類型是Json格式的。【MVC中經過JSOnResult來作到】,這個方法的參數就是要驗證的實體的屬性【必須,不然不能驗證,參數的大小寫無所謂。】,若是這個驗證的方法返回值是true,那麼就表名存在相同的用戶,咱們就返回false,給前臺頁面。代表驗證不經過。jquery
好了,直接說正題吧!數據庫
首先新建一個空白的MVC項目,在Model文件夾下,新建一個類RemoteUser:ide
public class RemoteUser { public string Name { get; set; } public string Email { get; set; } }
而後建一個測試的數據類:測試
public static class MyRemoteStaticData { public static List<RemoteUser> RemoteList { get { return new List<RemoteUser>() { new RemoteUser(){Name="Daniel",Email="Daniel@163.com"}, new RemoteUser(){Name="CFS",Email="CFS@163.com"} }; } } }
在新建一個控制器MyRemoteController 【主要用來Remote驗證】:url
using Server_Side_Validation_IN_MVC.StaticData; using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Mvc; namespace Server_Side_Validation_IN_MVC.Controllers { public class MyRemoteController : Controller { // GET: MyRemote
public JsonResult RemoteValidate(string name) //這裏的參數名字,必需要和視圖中文本框控件的名字同樣,但大小寫無所謂
{ //若是存在用戶名,即isExists=true
bool isExists = MyRemoteStaticData.RemoteList. Where(s => s.Name.ToLowerInvariant(). Equals(name.ToLower())).FirstOrDefault() != null; //就向前臺返回false,代表已經存在userName
return Json(!isExists,JsonRequestBehavior.AllowGet); } }
上面添加完驗證以後,咱們來修改一下Model實體:spa
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Mvc; namespace Server_Side_Validation_IN_MVC.Models { public class RemoteUser { [Remote("RemoteValidate", "MyRemote", ErrorMessage = "抱歉用戶名已經存在!請從新輸入!!!")] public string Name { get; set; } public string Email { get; set; } } }
而後在新建一個測試的控制器:插件
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Mvc; namespace Server_Side_Validation_IN_MVC.Controllers { public class UserController : Controller { public ActionResult AddRemoteUser() { return View(); } } }
添加AddRemoteUser視圖,【注意這裏,Remote Validation是須要引入Jquery插件和啓用客戶端驗證的】code
這裏勾選引入腳本庫,也主要是用來引入Jquery插件。orm
@model Server_Side_Validation_IN_MVC.Models.RemoteUser @{ ViewBag.Title = "AddRemoteUser"; } <h2>AddRemoteUser</h2> @using (Html.BeginForm()) { @Html.AntiForgeryToken() <div class="form-horizontal">
<h4>RemoteUser</h4>
<hr /> @Html.ValidationSummary(true, "", new { @class = "text-danger" }) <div class="form-group"> @Html.LabelFor(model => model.Name, htmlAttributes: new { @class = "control-label col-md-2" }) <div class="col-md-10"> @Html.EditorFor(model => model.Name, new { htmlAttributes = new { @class = "form-control" } }) @Html.ValidationMessageFor(model => model.Name, "", new { @class = "text-danger" }) </div>
</div>
<div class="form-group"> @Html.LabelFor(model => model.Email, htmlAttributes: new { @class = "control-label col-md-2" }) <div class="col-md-10"> @Html.EditorFor(model => model.Email, new { htmlAttributes = new { @class = "form-control" } }) @Html.ValidationMessageFor(model => model.Email, "", new { @class = "text-danger" }) </div>
</div>
<div class="form-group">
<div class="col-md-offset-2 col-md-10">
<input type="submit" value="Create" class="btn btn-default" />
</div>
</div>
</div> } <div> @Html.ActionLink("Back to List", "Index") </div>
<script src="~/Scripts/jquery-1.10.2.min.js"></script> <script src="~/Scripts/jquery.validate.min.js"></script> <script src="~/Scripts/jquery.validate.unobtrusive.min.js"></script>
而後修改一下默認的路由:
public static void RegisterRoutes(RouteCollection routes) { routes.IgnoreRoute("{resource}.axd/{*pathInfo}"); routes.MapRoute( name: "Default", url: "{controller}/{action}/{id}", defaults: new { controller = "User", action = "AddRemoteUser", id = UrlParameter.Optional } ); }
運行項目:
輸入測試數據:CFS,按Tab鍵後,自動就進行驗證了。
這裏咱們對Name字段就進行了Remote驗證,如今我想對Email字段進行驗證,須要使用到AdditionalFields,屬性,還須要另外添加一個驗證方法:
using Server_Side_Validation_IN_MVC.StaticData; using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Mvc; namespace Server_Side_Validation_IN_MVC.Controllers { public class MyRemoteController : Controller { // GET: MyRemote
public JsonResult RemoteValidate(string name) //這裏的參數名字,必需要和視圖中文本框控件的名字同樣,但大小寫無所謂
{ //若是存在用戶名,即isExists=true
bool isExists = MyRemoteStaticData.RemoteList. Where(s => s.Name.ToLowerInvariant(). Equals(name.ToLower())).FirstOrDefault() != null; //就向前臺返回false,代表已經存在userName
return Json(!isExists,JsonRequestBehavior.AllowGet); } public JsonResult RemoteValidationAddtional(string name, string email) { //若是存在用戶名,即isExists=true bool isExists = MyRemoteStaticData.RemoteList. Where(s => s.Name.ToLowerInvariant(). Equals(name.ToLower()) && s.Email.ToLowerInvariant().Equals(email.ToLower())).FirstOrDefault() != null; //就向前臺返回false,代表已經存在userName return Json(!isExists, JsonRequestBehavior.AllowGet); } } }
而後修改對應的實體類:
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Mvc; namespace Server_Side_Validation_IN_MVC.Models { public class RemoteUser { [Remote("RemoteValidate", "MyRemote", ErrorMessage = "抱歉用戶名已經存在!請從新輸入!!!")] public string Name { get; set; } //注意,這裏的AdditionalFields="Name",Name字段必須和Modle中的字段徹底同樣 [Remote("RemoteValidationAddtional", "MyRemote", AdditionalFields = "Name", ErrorMessage = "抱歉Email已經存在!請從新輸入!!!")] public string Email { get; set; } } }
接着運行項目:
輸入在測試類中寫的測試數據:
這裏就對兩個字段進行了Remote Validation了。
上面使用了AdditionalFields 驗證字段,若是咱們想要驗證不僅一個字段,能夠在AddtionalFiled裏面添加,以逗號分隔就好了。