ASP.net的驗(yàn)證控件淺析
<asp:RegularExpressionValidator ID="RegularExpressionValidator1" runat="server" ErrorMessage="此用戶名已注冊(cè)過" ControlToValidate = "txtName" ValidationExpression = "\S+@\S+\.\S+"></asp:RegularExpressionValidator>
通過自定義正則表達(dá)式,與需驗(yàn)證的控件進(jìn)行模式匹配。
以前面這段代碼為例:
ErrorMessage屬性表示當(dāng)驗(yàn)證不合法時(shí),出現(xiàn)錯(cuò)誤的信息;
ControlToValidate屬性表示需驗(yàn)證的控件ID;
ValidationExpression屬性指定為驗(yàn)證條件的正則表達(dá)式;
在這里貼上常用正則表達(dá)式字符及其含義:
編號(hào) 正則表達(dá)式字符 含義
1 [……] 匹配括號(hào)中的任何一個(gè)字符
2 [^……] 匹配不在括號(hào)中的任何一個(gè)字符
3 \w 匹配任何一個(gè)字符(a~z、A~Z和0~9)
4 \W 匹配任何一個(gè)空白字符
5 \s 匹配任何一個(gè)非空白字符
6 \S 與任何非單詞字符匹配
7 \d 匹配任何一個(gè)數(shù)字(0~9)
8 \D 匹配任何一個(gè)非數(shù)字(^0~9)
9 [\b] 匹配一個(gè)退格鍵字符
10 {n,m} 最少匹配前面表達(dá)式n次,最大為m次
11 {n,} 最少匹配前面表達(dá)式n次
12 {n} 恰恰匹配前面表達(dá)式n次
13 ? 匹配前面表達(dá)式0或1次 {0,1}
14 + 至少匹配前面表達(dá)式1次 {1,}
15 * 至少匹配前面表達(dá)式0次 {0,}
16 | 匹配前面表達(dá)式或后面表達(dá)式
17 (…) 在單元中組合項(xiàng)目
18 ^ 匹配字符串的開頭
19 $ 匹配字符串的結(jié)尾
20 \b 匹配字符邊界
21 \B 匹配非字符邊界的某個(gè)位置
同時(shí),列舉幾個(gè)常用的正則表達(dá)式:(有些是我自己用過的,有些是網(wǎng)上找的資料)
驗(yàn)證電子郵件:
"\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*”
\S+@\S+\.\S+
驗(yàn)證網(wǎng)址:
"\S+://\S+\.\S+”
驗(yàn)證郵政編碼:"\d{6}”
其他常用正則表達(dá)式:
表示0~9十個(gè)數(shù)字:"[0-9]”
表示任意個(gè)數(shù)字:"\d*”
表示中國大陸的固定電話號(hào)碼:"\d{3,4}-\d{7,8}”
驗(yàn)證由兩位數(shù)字、一個(gè)連字符再加5位數(shù)字組成的ID號(hào):"\d{2}-\d{5}”
②、自定義驗(yàn)證控件(CustomValidator)
Default頁面:
<asp:CustomValidator ID="CustomValidator1" runat="server" ErrorMessage="此用戶名已注冊(cè)過" ControlToValidate = "txtName" OnServerValidate ="ValidateName">
</asp:CustomValidator>
Defalult.cs頁面:
public void ValidateName(Object sender, ServerValidateEventArgs args)
{
SqlConnection myConn = new SqlConnection("Data Source=(local);Initial Catalog=Csharp;Integrated Security=True");
myConn.Open();
SqlCommand myCmd = new SqlCommand("select use_account from users", myConn);
SqlDataAdapter myDa = new SqlDataAdapter(myCmd);
DataSet myDs = new DataSet();
myDa.Fill(myDs);
for (int i = 0; i < myDs.Tables[0].Rows.Count; i++)
{
if (args.Value.ToString() == myDs.Tables[0].Rows[i][0].ToString())
{
args.IsValid = false;
break;
}
else
{
args.IsValid = true;
}
}
}
通過自定義服務(wù)器端的函數(shù)代碼,與前臺(tái)驗(yàn)證控件關(guān)聯(lián),形成一種假客戶端—當(dāng)前頁面驗(yàn)證的效果。
以上面前臺(tái)驗(yàn)證控件這段代碼為例:
ErrorMessage屬性表示當(dāng)驗(yàn)證不合法時(shí),出現(xiàn)錯(cuò)誤的信息;
ControlToValidate屬性表示需驗(yàn)證的控件ID;
OnServerValidate屬性表示與自定義函數(shù)相關(guān)聯(lián),以在服務(wù)器上執(zhí)行驗(yàn)證;
效果如下:

摘自 暗自在綻放
- ASP.NET表單驗(yàn)證方法詳解
- asp.net 繼承自Page實(shí)現(xiàn)統(tǒng)一頁面驗(yàn)證與錯(cuò)誤處理
- asp.net MaxLengthValidator 最大長度驗(yàn)證控件代碼
- jQuery 驗(yàn)證插件 Web前端設(shè)計(jì)模式(asp.net)
- ASP.NET MVC5添加驗(yàn)證(4)
- ASP.NETWeb服務(wù)器驗(yàn)證控件如何使用
- ASP.NET中HTML頁面的訪問驗(yàn)證設(shè)置方法
- 詳解ASP.NET MVC Form表單驗(yàn)證
- ASP.NET中Validation驗(yàn)證控件正則表達(dá)式特殊符號(hào)的說明
- 在ASP.NET 2.0中操作數(shù)據(jù)之十九:給編輯和新增界面增加驗(yàn)證控件
- 在ASP.NET 2.0中操作數(shù)據(jù)之三十九:在DataList的編輯界面里添加驗(yàn)證控件
相關(guān)文章
MVC使用Spring.Net應(yīng)用IOC(依賴倒置)學(xué)習(xí)筆記3
這篇文章主要為大家詳細(xì)介紹了MVC使用Spring.Net應(yīng)用IOC(依賴倒置),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09asp.net下Request.QueryString取不到值的解決方法
2008-01-01使用.NET Core實(shí)現(xiàn)餓了嗎拆紅包功能
這篇文章主要介紹了使用.NET Core實(shí)現(xiàn)餓了嗎拆紅包功能,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-07-07剖析ASP.NET MVC的DependencyResolver組件
這篇文章主要為大家剖析ASP.NET MVC的DependencyResolver組件,感興趣的小伙伴們可以參考一下2016-04-04Entity?Framework實(shí)體拆分多個(gè)表
這篇文章介紹了Entity?Framework實(shí)體拆分多個(gè)表的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03blog程序新版本V2.0 Beta完成,提供V1.0全部源碼下載
blog程序新版本V2.0 Beta完成,提供V1.0全部源碼下載...2007-06-06基于ABP架構(gòu)開發(fā)的.Net Core項(xiàng)目部署到IIS問題匯總
這篇文章介紹了基于ABP架構(gòu)開發(fā)的.Net Core項(xiàng)目部署到IIS問題匯總,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06.net連接oracle的3種實(shí)現(xiàn)方法
這篇文章介紹了.net連接oracle的3種實(shí)現(xiàn)方法,有需要的朋友可以才可以一下2013-07-07淺談Asp.net Mvc之Action如何傳多個(gè)參數(shù)的方法
本篇文章主要介紹了Asp.net Mvc之Action如何傳多個(gè)參數(shù)的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-08-08ASP.NET MVC視圖頁使用jQuery傳遞異步數(shù)據(jù)的幾種方式詳解
本文詳細(xì)講解了ASP.NET MVC視圖頁使用jQuery傳遞異步數(shù)據(jù)的幾種方式,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-09-09