ASP.NET表單驗證方法詳解
更新時間:2008年09月19日 23:57:45 作者:
在表單提交的時候,經(jīng)常需要對錄入信息的長度、格式、內(nèi)容等進行驗證,以便獲得合理的信息。在ASP.NET開發(fā)中主要的驗證方法,我總結(jié)了一下,主要有一下幾種,如有不足之處請朋友們予以指出。
<2>使用驗證控件
自定義驗證控件:
復(fù)制代碼 代碼如下:
<asp:CustomValidator ID="CustomValidator2" runat="server" ControlToValidate="tbMobile" ClientValidationFunction="checkCellPhone"></asp:CustomValidator>
正則表達式驗證控件(當然這種方法需要加入非空驗證)
復(fù)制代碼 代碼如下:
<asp:RegularExpressionValidator ID="revPhone" runat="server" ControlToValidate="tbPhone" ValidationExpression="^(013|015|13|15)\d{9}$" ErrorMessage="手機號碼格式錯誤!"></asp:RegularExpressionValidator>
<3>使用服務(wù)器端程序驗證
復(fù)制代碼 代碼如下:
public static bool ValidatePhone(string phone)
{
return System.Text.RegularExpressions.Regex.IsMatch(phone, @"^[1]+[3,5]+\d{9}");
}
上述的是一個簡單的應(yīng)用實例,只要你知道正則表達式的寫法,你可以隨意將上面實例中的正則表達式進行替換,將一些邏輯進行修改,就能夠滿足你在驗證方面,可以說足夠滿足你常用的驗證。在這里我也收集了一些常用的正則表達式,希望能夠?qū)Υ蠹矣兴鶐椭?
復(fù)制代碼 代碼如下:
匹配中文字符的正則表達式: [\u4e00-\u9fa5]
匹配雙字節(jié)字符(包括漢字在內(nèi)):[^\x00-\xff]
備注:可以用來計算字符串的長度(一個雙字節(jié)字符長度計2,ASCII字符計1)
匹配空白行的正則表達式:\n\s*\r
備注:可以用來刪除空白行
匹配HTML標記的正則表達式:<(\S*?)[^>]*>.*?</\1>|<.*? />
備注:網(wǎng)上流傳的版本太糟糕,上面這個也僅僅能匹配部分,對于復(fù)雜的嵌套標記依舊無能為力
匹配首尾空白字符的正則表達式:^\s*|\s*$
備注:可以用來刪除行首行尾的空白字符(包括空格、制表符、換頁符等等),非常有用的表達式
匹配Email地址的正則表達式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
匹配網(wǎng)址URL的正則表達式:[a-zA-z]+://[^\s]*
匹配帳號是否合法(字母開頭,允許5-16字節(jié),允許字母數(shù)字下劃線):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
匹配國內(nèi)電話號碼:\d{3}-\d{8}|\d{4}-\d{7}
備注:匹配形式如 0511-4405222 或 021-87888822
匹配騰訊QQ號:[1-9][0-9]{4,}
備注:騰訊QQ號從10000開始
匹配中國郵政編碼:[1-9]\d{5}(?!\d)
備注:中國郵政編碼為6位數(shù)字
匹配身份證:\d{15}|\d{18}
備注:中國的身份證為15位或18位
匹配ip地址:\d+\.\d+\.\d+\.\d+
備注:提取ip地址時有用
匹配特定數(shù)字:
^[1-9]\d*$ //匹配正整數(shù)
^-[1-9]\d*$ //匹配負整數(shù)
^-?[1-9]\d*$ //匹配整數(shù)
^[1-9]\d*|0$ //匹配非負整數(shù)(正整數(shù) + 0)
^-[1-9]\d*|0$ //匹配非正整數(shù)(負整數(shù) + 0)
^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$ //匹配正浮點數(shù)
^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$ //匹配負浮點數(shù)
^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$ //匹配浮點數(shù)
^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$ //匹配非負浮點數(shù)(正浮點數(shù) + 0)
^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$ //匹配非正浮點數(shù)(負浮點數(shù) + 0)
備注:處理大量數(shù)據(jù)時有用,具體應(yīng)用時注意修正
匹配特定字符串:
^[A-Za-z]+$ //匹配由26個英文字母組成的字符串
^[A-Z]+$ //匹配由26個英文字母的大寫組成的字符串
^[a-z]+$ //匹配由26個英文字母的小寫組成的字符串
^[A-Za-z0-9]+$ //匹配由數(shù)字和26個英文字母組成的字符串
^\w+$ //匹配由數(shù)字、26個英文字母或者下劃線組成的字符串
相關(guān)文章
ASP.NET通過第三方網(wǎng)站Bitly實現(xiàn)短鏈接地址程序
這篇文章主要介紹了ASP.NET通過第三方網(wǎng)站Bitly實現(xiàn)短鏈接地址程序的步驟,需要的朋友可以參考下。2016-06-06
ASP.NET導(dǎo)出數(shù)據(jù)到Excel的實現(xiàn)方法
在做asp.net程序時涉及到數(shù)據(jù)顯示的時候多數(shù)會要求打印,而網(wǎng)頁上的打印格式往往又不能滿足需求,經(jīng)常用的方法就是導(dǎo)入到Excel以后再進行打印。(仿佛這已經(jīng)是老生常談)今天在網(wǎng)上搜了一段打印的代碼,覺得不錯,需要打印的朋友可以看看。2013-07-07
使用Blazor框架實現(xiàn)在前端瀏覽器中導(dǎo)入和導(dǎo)出Excel
Blazor?是一個相對較新的框架,用于構(gòu)建具有?.NET?強大功能的交互式客戶端?Web?UI,本文主要介紹了如何在?Blazor?應(yīng)用程序中實現(xiàn)?SpreadJS?利用?.NET?的強大功能完成瀏覽器端的?Excel?導(dǎo)入導(dǎo)出,需要的可以參考一下2023-05-05

