數據驗證註解:經過在Models層,經過註解特性對模型屬性,進行註解設置,來實現數據驗證的功能。前端
主要命名空間:System.ComponentModel.DataAnnotations正則表達式
Requierd特性:服務器
n 設置必填屬性,驗證是否填寫內容ui
n 服務端Model屬性添加[Required]spa
n 前端提示錯誤信息3d
@Html.ValidationMessageFor()code
示例代碼:orm
①在Models層上引入System.ComponentModel.DataAnnotations命名空間,併爲屬性添加[Required]約束blog
public class Student { [Required] //表示能夠在前臺展現姓名字段 [DisplayName("姓名")] public string name { get; set; } [Required] [DisplayName("性別")] public string sex { get; set; } [Required] [DisplayName("年齡")] public int age { get; set; } }
②前端頁面加上對應的@Html.ValidationMessageFor(Model => Model.屬性)註解,表示對對應的參數須要驗證,會顯示錯誤信息;ci
<!--表示提交到本類對應的Controller控制器上--> @using (Html.BeginForm()) { <div> @Html.LabelFor(Model => Model.name) @Html.TextBoxFor(Model => Model.name) @Html.ValidationMessageFor(Model => Model.name) </div> <div> @Html.LabelFor(Model => Model.sex) @Html.TextBoxFor(Model => Model.sex) @Html.ValidationMessageFor(Model => Model.sex) </div> <div> @Html.LabelFor(Model => Model.age) @Html.TextBoxFor(Model => Model.age) @Html.ValidationMessageFor(Model => Model.age) </div> <input type="submit" value="提交"/> }
③對應的提交Controller增長[HttpPost]提交方式,傳入提交Model參數,顯示到界面上;
[HttpPost] public ActionResult Contact(Student stu) { return View(stu); }
若是前臺頁面數據爲空,則會提示對應錯誤信息:
StringLength特性驗證輸入字符串長度;
語法:
public class Student { [Required] //表示能夠在前臺展現姓名字段 [DisplayName("姓名")] [StringLength(20, MinimumLength = 5)] //設置最大輸入長度爲20個字符串,最小輸入長度爲5個字符串 public string name { get; set; } [Required] [DisplayName("性別")] public string sex { get; set; } [Required] [DisplayName("年齡")] public int age { get; set; } }
驗證顯示結果:
RegularExpression表示正則表達式驗證特性;
使用方式:[RegularExpression(表達式)]
[RegularExpression("[a-zA-Z]{5,20}")] public string name { get; set; }
驗證顯示結果:
Range特性:主要用於驗證數字類型的最大值和最小值;
使用方式:[Range(10,20)]
[Range(10, 20)] //限制年齡範圍必須是10-20歲 [Range(typeof(decimal), "10.0", "20.0")] //限制年齡範圍及類型 public int age { get; set; }
Remote特性:主要是將屬性數據發送到服務器,進行服務器驗證後,返回信息
使用方式:[Remote(方法,控制器)]
Remote能夠在任意控制器中加入判斷的方法,在前端執行參數驗證時每次調用該控制器上的方法進行驗證,經過後返回視圖結果:
public class Student { //Model類上面加上註解 [Remote("CheakName", "Home")] [Required] [DisplayName("姓名")] public string name { get; set; } }
遠端驗證方法:
ErrorMessage註解屬性用於自定義錯誤信息顯示,
用法:
[Required(ErrorMessage=「錯誤信息」)]
public class Student { [Required(ErrorMessage="姓名不能爲空!")] [DisplayName("姓名")] public string name { get; set; } [Required(ErrorMessage="性別不能爲空!")] [DisplayName("性別")] public string sex { get; set; } [Required(ErrorMessage="年齡不能爲空!")] [DisplayName("年齡")] public string age{get;set;} }
Compare特性用於比較輸入的內容是否相同
用法:
[Compare(「屬性名稱」)]
示例:
@using (Html.BeginForm()) { <div> @Html.LabelFor(Model => Model.name) @Html.TextBoxFor(Model => Model.name) @Html.ValidationMessageFor(Model => Model.name) </div> <div> @Html.LabelFor(Model => Model.name2) @Html.TextBoxFor(Model => Model.name2) @Html.ValidationMessageFor(Model => Model.name2) </div> <input type="submit" value="保存" /> } public class Student { [Required(ErrorMessage="姓名不能爲空!")] [DisplayName("姓名")] public string name { get; set; } [Compare("name")] [Required(ErrorMessage = "姓名2不能爲空!")] [DisplayName("姓名")] public string name2 { get; set; } }