MVC-Model数据注解(一)-系统(DataAnnotations)
要使用验证,首先,web.config要开户验证:
<appSettings> <add key="ClientValidationEnabled" value="true" /> <add key="UnobtrusiveJavaScriptEnabled" value="true" /> </appSettings>
1、基础验证:
using System.ComponentModel.DataAnnotations; //字段显示名称 [Display(Name = "用户名")] //数据类型(比如生成的文本框的类型) [DataType(DataType.Password)] //非空验证 [Required(ErrorMessage = "*")] //字符长度验证 [StringLength(50, ErrorMessage = "字符长度应在6-50之间", MinimumLength = 6)] //验证范围 [Range(10, 120, ErrorMessage = "年龄应在10-120之间")] //正则表达式验证 [RegularExpression(@"[A-Za-z0-9._%+-]+@[A-Za-z0-9._]+.[A-Za-z]{2,4}", ErrorMessage = "邮箱格式不正确")] //邮箱格式验证 [EmailAddress(ErrorMessage = "邮箱格式不正确")] //比较验证 [Compare("Password", ErrorMessage = "密码不一致")] public string PasswordConfirm { get; set; }
其中:ErrorMessage里面是自定义错误信息,如果不加这个属性,将显示系统默认的提示错误信息(系统提示比较生硬可能),一般都加上这个属性。
ErrorMessage允许开发者使用{0}占位符来显示字段的显示名(即[Display(Name = "用户名")]),如果没有Display特性,那么会显示属性名。如:
[Required(ErrorMessage = "{0}不能为空!")] [Display(Name = "用户名")] public string UserName { get; set; }
如果验证的特性中还有其他参数,那么ErrorMessage可以用占位符直接显示其他参数,如:
[Required] [StringLength(100, ErrorMessage = "请输入{2}到{1}位的{0}。", MinimumLength = 6)] [DataType(DataType.Password)] [Display(Name = "密码")] public string Password { get; set; } //系统会提示:“请输入6到100位的密码”。
2、附加验证:
附加验证是System.Web.Mvc中额外添加的验证特性,所以使用时必须添加using System.Web.Mvc
Remote(远程验证,即ajax验证)
虽然asp.net mvc3提供了很多在model中直接验证数据的特性,但是很多逻辑复杂的验证没办法在model中来验证,所以mvc3框架提供了这个远程验证特性,他允许开发者在Controller中用C#代码来验证数据的有效性。
一个很经典的应用时验证用户名是否重复。这个数据验证没办法在客户端验证,除非将所有的用户名都发往客户端(显然这是不可能的)。所以Remote特性只进行服务器端验证。但是它是通过异步的方式进行验证,所以有更好的用户体验。
Model:
[Required] [Display(Name = "用户名")] [Remote("CheckUserName","Account")] public string UserName { get; set; }
Controller:
public JsonResult CheckUserName(string userName) { var result = userName == "admin"; return Json(result, JsonRequestBehavior.AllowGet); }
验证结果:
注意:如果要Post提交,则需要加上HttpMethod=“POST”:
[Display(Name = "用户名")] [Remote("CheckUserName","Account", HttpMethod="POST")] public string UserName { get; set; }
而Controller中也可以直接接受Post的请求,当然你加上[Httppost]也是可以的:
//[HttpPost] public JsonResult CheckUserName(string userName) { var result = userName != "admin"; return Json(result, JsonRequestBehavior.AllowGet); }
注意:远程验证控制器(remote)方法参数必须和view model中需要远程验证的属性一致,但不区分大小写。而且Remote验证是通过get方式请求的。
上面的是mvc框架的几种常用的数据注解,除了remote是mvc特有的特性,其他的特性都在System.ComponentModel.DataAnnotations中。