.Net項(xiàng)目中一些常用驗(yàn)證操作
在項(xiàng)目中需要對(duì)用戶輸入的信息,以及一些方法生成的結(jié)果進(jìn)行驗(yàn)證,一般在項(xiàng)目中較多的采用js插件或js來(lái)進(jìn)行有關(guān)信息的校驗(yàn),但是從項(xiàng)目安全性的角度進(jìn)行考慮,可對(duì)系統(tǒng)進(jìn)行js注入。
如果在后臺(tái)對(duì)用戶輸入的信息進(jìn)行驗(yàn)證會(huì)相對(duì)的安全,在出現(xiàn)信息驗(yàn)證不合法時(shí),可以直接在程序中拋出異常,終止程序的運(yùn)行。
現(xiàn)在提供幾種較為常用的驗(yàn)證方法,可以減少在項(xiàng)目中開(kāi)發(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; } }
9.判斷是不是純中文:
/// <summary> /// 判斷是不是純中文 /// </summary> /// <param name="value"></param> /// <returns></returns> public static bool IsChinese(string value) { var regex = new System.Text.RegularExpressions.Regex(@"^[\u4E00-\u9FA5\uF900-\uFA2D]+$", RegexOptions.IgnoreCase); return regex.Match(value).Success; }
10.判斷一個(gè)字符串是否為手機(jī)號(hào)碼:
/// <summary> /// 判斷一個(gè)字符串是否為手機(jī)號(hào)碼 /// </summary> /// <param name="value"></param> /// <returns></returns> public static bool IsMobileNum(string value) { var regex = new System.Text.RegularExpressions.Regex(@"^(13|15)\d{9}$", RegexOptions.IgnoreCase); return regex.Match(value).Success; }
11.判斷一個(gè)字符串是否為電話號(hào)碼:
/// <summary> /// 判斷一個(gè)字符串是否為電話號(hào)碼 /// </summary> /// <param name="value"></param> /// <returns></returns> public static bool IsPhoneNum(string value) { var regex = new System.Text.RegularExpressions.Regex(@"^(86)?(-)?(0\d{2,3})?(-)?(\d{7,8})(-)?(\d{3,5})?$", RegexOptions.IgnoreCase); return regex.Match(value).Success; }
12.判斷一個(gè)字符串是否為網(wǎng)址:
/// <summary> /// 判斷一個(gè)字符串是否為網(wǎng)址 /// </summary> /// <param name="value"></param> /// <returns></returns> public static bool IsUrl(string value) { var regex = new System.Text.RegularExpressions.Regex(@"(http://)?([\w-]+\.)*[\w-]+(/[\w- ./?%&=]*)?", RegexOptions.IgnoreCase); return regex.Match(value).Success; }
13.判斷一個(gè)字符串是否為IP地址:
/// <summary> /// 判斷一個(gè)字符串是否為IP地址 /// </summary> /// <param name="value"></param> /// <returns></returns> public static bool IsIp(string value) { var regex = new System.Text.RegularExpressions.Regex(@"^(((2[0-4]{1}[0-9]{1})|(25[0-5]{1}))|(1[0-9]{2})|([1-9]{1}[0-9]{1})|([0-9]{1})).(((2[0-4]{1}[0-9]{1})|(25[0-5]{1}))|(1[0-9]{2})|([1-9]{1}[0-9]{1})|([0-9]{1})).(((2[0-4]{1}[0-9]{1})|(25[0-5]{1}))|(1[0-9]{2})|([1-9]{1}[0-9]{1})|([0-9]{1})).(((2[0-4]{1}[0-9]{1})|(25[0-5]{1}))|(1[0-9]{2})|([1-9]{1}[0-9]{1})|([0-9]{1}))$", RegexOptions.IgnoreCase); return regex.Match(value).Success; }
14.判斷一個(gè)字符串是否為字母加數(shù)字:
/// <summary> /// 判斷一個(gè)字符串是否為字母加數(shù)字 /// Regex("[a-zA-Z0-9]?" /// </summary> /// <param name="value"></param> /// <returns></returns> public static bool IsWordAndNum(string value) { var regex = new System.Text.RegularExpressions.Regex("[a-zA-Z0-9]?"); return regex.Match(value).Success; }
以上的驗(yàn)證方法采用方法封裝,在實(shí)際的項(xiàng)目中,可以將所有的方法封裝在類(lèi)中,方法都定義為靜態(tài)方法,在項(xiàng)目中可直接調(diào)用其中的驗(yàn)證方法,可以極大的提升項(xiàng)目的開(kāi)發(fā)速度。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- ASP.NET驗(yàn)證碼實(shí)現(xiàn)(附源碼)
- 深入學(xué)習(xí).net驗(yàn)證碼生成及使用方法
- ASP.NET中HTML頁(yè)面的訪問(wèn)驗(yàn)證設(shè)置方法
- ASP.NETWeb服務(wù)器驗(yàn)證控件如何使用
- asp.net中的窗體身份驗(yàn)證(最簡(jiǎn)單篇)
- ASP.NET MVC5添加驗(yàn)證(4)
- ASP.NET實(shí)現(xiàn)用戶注冊(cè)和驗(yàn)證功能(第4節(jié))
- ASP.NET MVC5網(wǎng)站開(kāi)發(fā)之登錄、驗(yàn)證和注銷(xiāo)管理員篇1(六)
- ASP.NET MVC5驗(yàn)證系列之Fluent Validation
- ASP.NET MVC5驗(yàn)證系列之客戶端驗(yàn)證
相關(guān)文章
用vs調(diào)試sql存儲(chǔ)過(guò)程圖文介紹
想必大家應(yīng)該有給存儲(chǔ)過(guò)程找錯(cuò)誤的經(jīng)歷吧,一遍遍的去讀sql代碼,一句一句的測(cè)試,發(fā)現(xiàn)一個(gè)小錯(cuò)誤可能都要用很長(zhǎng)的時(shí)間,接下來(lái)將介紹使用vs2010調(diào)試存儲(chǔ)過(guò)程,感興趣的朋友可以不要錯(cuò)過(guò)了啊2013-02-02sqlserver 批量數(shù)據(jù)替換助手V1.0版發(fā)布
前段時(shí)間網(wǎng)站被掛馬,數(shù)據(jù)庫(kù)表中很多文本字段都被加上了一段js腳本。修復(fù)完程序漏洞之后便開(kāi)始著手清理這些被注入的數(shù)據(jù),其間參考了一些網(wǎng)上的方法,大都是寫(xiě)一個(gè)存儲(chǔ)過(guò)程進(jìn)行一個(gè)表一個(gè)表逐一清理。2011-10-10System.Runtime.InteropServices.COMException的解決方法
完美解決“換另一臺(tái)電腦上用VS2008繼續(xù)開(kāi)發(fā)web項(xiàng)目時(shí)出現(xiàn)“System.Runtime.InteropServices.COMException”,然后是加載不了項(xiàng)目?!?2009-03-03深入解讀ASP.NET Core身份認(rèn)證過(guò)程實(shí)現(xiàn)
這篇文章主要介紹了深入解讀ASP.NET Core身份認(rèn)證過(guò)程實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10解決ASP.NET Core Mvc文件上傳限制問(wèn)題實(shí)例
本篇文章主要介紹了解決ASP.NET Core Mvc文件上傳限制問(wèn)題,具有一定的參考價(jià)值,有需要的可以了解一下。2016-11-11ASP.NET中ListView(列表視圖)的使用前臺(tái)綁定附源碼
ListView(列表視圖)想必大家都知道吧,接下來(lái)本文將介紹下ListView的使用前臺(tái)綁定,感興趣的你可不要錯(cuò)過(guò)本文了哈2013-03-03防SQL注入 生成參數(shù)化的通用分頁(yè)查詢語(yǔ)句
前些時(shí)間看了玉開(kāi)兄的“如此高效通用的分頁(yè)存儲(chǔ)過(guò)程是帶有sql注入漏洞的”這篇文章,才突然想起某個(gè)項(xiàng)目也是使用了累似的通用分頁(yè)存儲(chǔ)過(guò)程。2010-07-07ASP.NET在底層類(lèi)庫(kù)中獲取Session C#類(lèi)中獲取Session
本文介紹一些在類(lèi)庫(kù)中獲取Session、Page、Resposne、Request的方法和步驟,方便初學(xué)者使用。2016-03-03Repeater的FooterTemplate顯示某列總計(jì)思路與代碼
在Repeater的FooterTemplate顯示某列總計(jì),接下來(lái)與大家分享詳細(xì)的實(shí)現(xiàn)方案,感興趣的各位可以參考下哈2013-03-03