①、數(shù)據(jù)格式驗(yàn)證控件(RegularExpressionValidator)
復(fù)制代碼 代碼如下:
asp:RegularExpressionValidator ID="RegularExpressionValidator1" runat="server" ErrorMessage="此用戶(hù)名已注冊(cè)過(guò)" ControlToValidate = "txtName" ValidationExpression = "\S+@\S+\.\S+">/asp:RegularExpressionValidator>
通過(guò)自定義正則表達(dá)式,與需驗(yàn)證的控件進(jìn)行模式匹配。
以前面這段代碼為例:
ErrorMessage屬性表示當(dāng)驗(yàn)證不合法時(shí),出現(xiàn)錯(cuò)誤的信息;
ControlToValidate屬性表示需驗(yàn)證的控件ID;
ValidationExpression屬性指定為驗(yàn)證條件的正則表達(dá)式;
在這里貼上常用正則表達(dá)式字符及其含義:
復(fù)制代碼 代碼如下:
編號(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 ^ 匹配字符串的開(kāi)頭
19 $ 匹配字符串的結(jié)尾
20 \b 匹配字符邊界
21 \B 匹配非字符邊界的某個(gè)位置
同時(shí),列舉幾個(gè)常用的正則表達(dá)式:(有些是我自己用過(guò)的,有些是網(wǎng)上找的資料)
復(fù)制代碼 代碼如下:
驗(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*”
表示中國(guó)大陸的固定電話號(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頁(yè)面:
復(fù)制代碼 代碼如下:
asp:CustomValidator ID="CustomValidator1" runat="server" ErrorMessage="此用戶(hù)名已注冊(cè)過(guò)" ControlToValidate = "txtName" OnServerValidate ="ValidateName">
/asp:CustomValidator>
Defalult.cs頁(yè)面:
復(fù)制代碼 代碼如下:
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;
}
}
}
通過(guò)自定義服務(wù)器端的函數(shù)代碼,與前臺(tái)驗(yàn)證控件關(guān)聯(lián),形成一種假客戶(hù)端—當(dāng)前頁(yè)面驗(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è)面驗(yàn)證與錯(cuò)誤處理
- asp.net MaxLengthValidator 最大長(zhǎng)度驗(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è)面的訪問(wèn)驗(yàn)證設(shè)置方法
- 詳解ASP.NET MVC Form表單驗(yàn)證
- ASP.NET中Validation驗(yàn)證控件正則表達(dá)式特殊符號(hào)的說(shuō)明
- 在ASP.NET 2.0中操作數(shù)據(jù)之十九:給編輯和新增界面增加驗(yàn)證控件
- 在ASP.NET 2.0中操作數(shù)據(jù)之三十九:在DataList的編輯界面里添加驗(yàn)證控件