在項(xiàng)目中需要對(duì)用戶輸入的信息,以及一些方法生成的結(jié)果進(jìn)行驗(yàn)證,一般在項(xiàng)目中較多的采用js插件或js來進(jìn)行有關(guān)信息的校驗(yàn),但是從項(xiàng)目安全性的角度進(jìn)行考慮,可對(duì)系統(tǒng)進(jìn)行js注入。
專注于為中小企業(yè)提供成都網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計(jì)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)宣州免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了成百上千家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。
如果在后臺(tái)對(duì)用戶輸入的信息進(jìn)行驗(yàn)證會(huì)相對(duì)的安全,在出現(xiàn)信息驗(yàn)證不合法時(shí),可以直接在程序中拋出異常,終止程序的運(yùn)行。
現(xiàn)在提供幾種較為常用的驗(yàn)證方法,可以減少在項(xiàng)目中開發(fā)時(shí)間和錯(cuò)誤性:
1.判斷域名:
/// <summary> /// 普通的域名 /// </summary> /// <param name="value"></param> /// <returns></returns> public static bool IsCommonDomain(string value) { return QuickValidate("^(www.)?(\\w+\\.){1,3}(org|org.cn|gov.cn|com|cn|net|cc)$", value.ToLower()); }
2.檢查一個(gè)字符串是否是純數(shù)字構(gòu)成的,一般用于查詢字符串參數(shù)的有效性驗(yàn)證:
/// <summary> /// 檢查一個(gè)字符串是否是純數(shù)字構(gòu)成的,一般用于查詢字符串參數(shù)的有效性驗(yàn)證。 /// </summary> /// <param name="value">需驗(yàn)證的字符串。</param> /// <returns>是否合法的bool值。</returns> public static bool IsNumeric(string value) { return QuickValidate("^[-]?[1-9]*[0-9]*$", value); }
3.檢查一個(gè)字符串是否是純字母和數(shù)字構(gòu)成的,一般用于查詢字符串參數(shù)的有效性驗(yàn)證:
/// <summary> /// 檢查一個(gè)字符串是否是純字母和數(shù)字構(gòu)成的,一般用于查詢字符串參數(shù)的有效性驗(yàn)證。 /// </summary> /// <param name="value">需驗(yàn)證的字符串。</param> /// <returns>是否合法的bool值。</returns> public static bool IsLetterOrNumber(string value) { return QuickValidate("^[a-zA-Z0-9_]*$", value); }
4.判斷是否是數(shù)字,包括小數(shù)和整數(shù):
/// <summary> /// 判斷是否是數(shù)字,包括小數(shù)和整數(shù)。 /// </summary> /// <param name="value">需驗(yàn)證的字符串。</param> /// <returns>是否合法的bool值。</returns> public static bool IsNumber(string value) { return QuickValidate("^(0|([1-9]+[0-9]*))(.[0-9]+)?$", value); }
5.快速驗(yàn)證一個(gè)字符串是否符合指定的正則表達(dá)式:
/// <summary> /// 快速驗(yàn)證一個(gè)字符串是否符合指定的正則表達(dá)式。 /// </summary> /// <param name="express">正則表達(dá)式的內(nèi)容。</param> /// <param name="value">需驗(yàn)證的字符串。</param> /// <returns>是否合法的bool值。</returns> public static bool QuickValidate(string express, string value) { var myRegex = new System.Text.RegularExpressions.Regex(express); return value.Length != 0 && myRegex.IsMatch(value); }
6.判斷一個(gè)字符串是否為郵件:
/// <summary> /// 判斷一個(gè)字符串是否為郵件 /// </summary> /// <param name="value"></param> /// <returns></returns> public static bool IsEmail(string value) { var regex = new System.Text.RegularExpressions.Regex(@"^\w+([-+.]\w+)*@(\w+([-.]\w+)*\.)+([a-zA-Z]+)+$", RegexOptions.IgnoreCase); return regex.Match(value).Success; }
7.判斷一個(gè)字符串是否為郵編:
/// <summary> /// 判斷一個(gè)字符串是否為郵編 /// </summary> /// <param name="value"></param> /// <returns></returns> public static bool IsZipCode(string value) { return QuickValidate("^([0-9]{6})$", value); }
8.判斷一個(gè)字符串是否為ID格式:
/// <summary> /// 判斷一個(gè)字符串是否為ID格式 /// </summary> /// <param name="value"></param> /// <returns></returns> public static bool IsIdCard(string value) { System.Text.RegularExpressions.Regex regex; string[] strArray; if ((value.Length != 15) && (value.Length != 0x12)) { return false; } if (value.Length == 15) { regex = new System.Text.RegularExpressions.Regex(@"^(\d{6})(\d{2})(\d{2})(\d{2})(\d{3})$"); if (!regex.Match(value).Success) { return false; } strArray = regex.Split(value); try { var dateTime = new DateTime(int.Parse("19" + strArray[2]), int.Parse(strArray[3]), int.Parse(strArray[4])); return true; } catch { return false; } } regex = new System.Text.RegularExpressions.Regex(@"^(\d{6})(\d{4})(\d{2})(\d{2})(\d{3})([0-9Xx])$"); if (!regex.Match(value).Success) { return false; } strArray = regex.Split(value); try { var dateTime = new DateTime(int.Parse(strArray[2]), int.Parse(strArray[3]), int.Parse(strArray[4])); return true; } catch { return false; } }
以上的驗(yàn)證方法采用方法封裝,在實(shí)際的項(xiàng)目中,可以將所有的方法封裝在類中,方法都定義為靜態(tài)方法,在項(xiàng)目中可直接調(diào)用其中的驗(yàn)證方法,可以極大的提升項(xiàng)目的開發(fā)速度。
新聞名稱:DotNet項(xiàng)目中的一些常用驗(yàn)證操作
當(dāng)前鏈接:http://chinadenli.net/article42/giopec.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供搜索引擎優(yōu)化、用戶體驗(yàn)、網(wǎng)站排名、響應(yīng)式網(wǎng)站、面包屑導(dǎo)航、靜態(tài)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)