国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

asp.net mvc3 數據驗證(三)—自定義數據注解

2019-11-10 18:25:44
字體:
來源:轉載
供稿:網友
前兩節講的都是asp.net mvc3預先設定的數據注解,但是系統自由的數據注解肯定不適合所有的場合,所以有時候我們需要自定義數據注解。        自定義數據注解有兩種,一種是直接寫在模型對象中,這樣做的好處是驗證時只需要關心一種模型對象的驗證邏輯,缺點也是顯而易見的,那就是不能重用。                                            還有一種是封裝在自定義的數據注解中,優點是可重用,缺點是需要應對不同類型的模型。        現在我們以封裝在自定義數據注解中的方法為例看下如何在asp.net mvc3中自定義數據注解以及使用。 一、自定義屬性級別的驗證        首先,所有的數據注解都應繼承于System.ComponentModel.DataAnnotations命名空間中的ValidationAttribute類。            重寫其PRotected virtual ValidationResult IsValid(object value, ValidationContext validationContext);例如:        我們需要寫一個UserName不能超過10個字母的數據注解(你可能會說這不是有的StringLength么,好吧,僅以此為例,我真沒想到其他的需要自定義數據注解的好例子)。        (1)新建一個類MaxLengthAttribute,代碼如下:復制代碼
    public class MyMaxLengthAttribute : ValidationAttribute    {        private readonly int MaxLength;         public MyMaxLengthAttribute(int maxLength)        {            MaxLength = maxLength;        }         protected override ValidationResult IsValid(object value, ValidationContext validationContext)        {            string content = value.ToString();            if (content.Length > MaxLength)            {                return new ValidationResult("輸入的字符太多了!^_^");            }            return ValidationResult.Success;            //return base.IsValid(value, validationContext);        }復制代碼        第二步就是像正常使用asp.net自帶的數據注解一樣使用,如:        
        [Required(ErrorMessageResourceType=typeof(ErrorMessage),ErrorMessageResourceName="UserRequire")]        [Display(Name = "用戶名")]        [MyMaxLengthAttribute(10)]        [Remote("CheckUserName","Account", HttpMethod="POST")]        public string UserName { get; set; }        好了,只需要這樣簡單的兩步就可以實現了。

驗證結果:        對于自定義的數據注解由于是繼承于System.ComponentModel.DataAnnotations命名空間中的ValidationAttribute類,所以它的一些屬性也可以使用,比如ErrorMessage,如:
        [Required(ErrorMessageResourceType=typeof(ErrorMessage),ErrorMessageResourceName="UserRequire")]        [Display(Name = "用戶名")]        [MyMaxLengthAttribute(10,ErrorMessage="{0}字數太多")]        [Remote("CheckUserName","Account", HttpMethod="POST")]        public string UserName { get; set; }        需要注意的是,自定義的數據注解不支持客戶端驗證,所有的數據需要提交之后再服務端驗證,所以如果要同時實現客戶端驗證需要自己寫js驗證。 但是這樣的驗證有一個問題,就是默認的驗證信息不能實現直接顯示Display Name,所以需要如下更改:復制代碼
    public class MyMaxLengthAttribute : ValidationAttribute    {        private readonly int MaxLength;         public MyMaxLengthAttribute(int maxLength ):base("{0}的字符太多了!")        {            MaxLength = maxLength;        }         protected override ValidationResult IsValid(object value, ValidationContext validationContext)        {            string content = value.ToString();            if (content.Length > MaxLength)            {                //return new ValidationResult("輸入的字符太多了!^_^");                string errorMessage = FormatErrorMessage(validationContext.DisplayName);                 return new ValidationResult(errorMessage);            }            return ValidationResult.Success;            //return base.IsValid(value, validationContext);        }    }復制代碼  驗證結果:

 二、自定義Model級別的驗證(IValidatableObject)        這個接口是為了實現Model的自驗證(self-validating)的,是asp.net mvc3 新增的驗證特性。這個特性和普通數據注解的區別是普通數據注解僅僅只能驗證Model的一個屬性,而實現了IValidatableObject接口的自驗證則在Model的級別來驗證,比如驗證Model的幾個屬性之間的關系等。        例如,我要驗證兩次輸入的密碼相同(好吧,我又把系統自帶的驗證再寫一遍)。        (1)首先,要將需要驗證的Model實現IValidatableObject接口。     public class RegisterModel : IValidatableObject        (2)在Model中實現Validate方法:復制代碼
        public IEnumerable<ValidationResult> Validate(ValidationContext validationContent)        {            if (PassWord != ConfirmPassword)            {                yield return new ValidationResult("兩次輸入的密碼不同!", new[] { "Password" });            }        }復制代碼

 

        這個方法在提交Model時會自動驗證兩次輸入的密碼是否相同,如果不同則會提示,如下:

 注意:1、自驗證只能把方法寫在需要驗證的Model中,所以這種自驗證的代碼無法重用;            2、自驗證的返回值是IEnumerable<ValidationResult>,而不是ValidationResult,所以返回值可以不止一個驗證錯誤。            3、Validate方法沒有傳入value參數,也就是意味著Validate方法可以直接訪問Model中的屬性值。            4、返回值使用的是yield return來構建枚舉返回值,第二個參數是指定錯誤信息綁定的屬性,因為是string數組,所以可以關聯多個屬性。

最后附上常用正則表達式

數字:"^[0-9]*$"。

n位的數字:"^/d{n}$"。

至少n位的數字:"^/d{n,}$"。

m~n位的數字:。"^/d{m,n}$"

零和非零開頭的數字:"^(0|[1-9][0-9]*)$"。

有兩位小數的正實數:"^[0-9]+(.[0-9]{2})?$"。

有1~3位小數的正實數:"^[0-9]+(.[0-9]{1,3})?$"。

非零的正整數:"^/+?[1-9][0-9]*$"。

非零的負整數:"^/-[1-9][]0-9"*$。

長度為3的字符:"^.{3}$"。

由26個英文字母組成的字符串:"^[A-Za-z]+$"。

由26個大寫英文字母組成的字符串:"^[A-Z]+$"。

由26個小寫英文字母組成的字符串:"^[a-z]+$"。

由數字和26個英文字母組成的字符串:"^[A-Za-z0-9]+$"。

由數字、26個英文字母或者下劃線組成的字符串:"^/w+$"。

驗證用戶密碼:"^[a-zA-Z]/w{5,17}$"正確格式為:以字母開頭,長度在6~18之間,只能包含字符、數字和下劃線。

驗證是否含有^%&’,;=?$/"等字符:"[^%&’,;=?$/x22]+"。

只能輸入漢字:"^[/u4e00-/u9fa5]{0,}$"

驗證Email地址:"^/w+([-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)*$"。

驗證InternetURL:"^http://([/w-]+/.)+[/w-]+(/[/w-./?%&=]*)?$"。

驗證電話號碼:"^(/(/d{3,4}-)|/d{3.4}-)?/d{7,8}$"正確格式為:"XXX-XXXXXXX"、"XXXX- XXXXXXXX"、"XXX-XXXXXXX"、"XXX-XXXXXXXX"、"XXXXXXX"和"XXXXXXXX"。

驗證身份證號(15位或18位數字):"^/d{15}|/d{18}$"。

驗證一年的12個月:"^(0?[1-9]|1[0-2])$"正確格式為:"01"~"09"和"1"~"12"。

驗證一個月的31天:"^((0?[1-9])|((1|2)[0-9])|30|31)$"正確格式為;"01"~"09"和"1"~"31"。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 措勤县| 呼和浩特市| 泗洪县| 惠水县| 邯郸县| 西乌珠穆沁旗| 遂平县| 棋牌| 姜堰市| 巴中市| 图木舒克市| 临泉县| 内乡县| 上饶县| 新邵县| 阳高县| 张家口市| 永清县| 改则县| 肇东市| 卫辉市| 保定市| 六盘水市| 都安| 姜堰市| 安徽省| 剑川县| 中西区| 白沙| 桓仁| 盖州市| 广丰县| 多伦县| 铁岭市| 镇康县| 凌源市| 灌云县| 北海市| 察哈| 谢通门县| 岐山县|