程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> ASP.NET基礎 >> ASP.net的驗證控件淺析

ASP.net的驗證控件淺析

編輯:ASP.NET基礎
①、數據格式驗證控件(RegularExpressionValidator)
復制代碼 代碼如下:
<asp:RegularExpressionValidator ID="RegularExpressionValidator1" runat="server" ErrorMessage="此用戶名已注冊過" ControlToValidate = "txtName" ValidationExpression = "\S+@\S+\.\S+"></asp:RegularExpressionValidator>

通過自定義正則表達式,與需驗證的控件進行模式匹配。
以前面這段代碼為例:
ErrorMessage屬性表示當驗證不合法時,出現錯誤的信息;
ControlToValidate屬性表示需驗證的控件ID;
ValidationExpression屬性指定為驗證條件的正則表達式;
在這裡貼上常用正則表達式字符及其含義:
復制代碼 代碼如下:
編號 正則表達式字符 含義
1 [……] 匹配括號中的任何一個字符
2 [^……] 匹配不在括號中的任何一個字符
3 \w 匹配任何一個字符(a~z、A~Z和0~9)
4 \W 匹配任何一個空白字符
5 \s 匹配任何一個非空白字符
6 \S 與任何非單詞字符匹配
7 \d 匹配任何一個數字(0~9)
8 \D 匹配任何一個非數字(^0~9)
9 [\b] 匹配一個退格鍵字符
10 {n,m} 最少匹配前面表達式n次,最大為m次
11 {n,} 最少匹配前面表達式n次
12 {n} 恰恰匹配前面表達式n次
13 ? 匹配前面表達式0或1次 {0,1}
14 + 至少匹配前面表達式1次 {1,}
15 * 至少匹配前面表達式0次 {0,}
16 | 匹配前面表達式或後面表達式
17 (…) 在單元中組合項目
18 ^ 匹配字符串的開頭
19 $ 匹配字符串的結尾
20 \b 匹配字符邊界
21 \B 匹配非字符邊界的某個位置

同時,列舉幾個常用的正則表達式:(有些是我自己用過的,有些是網上找的資料)
復制代碼 代碼如下:
驗證電子郵件:
"\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*”
\S+@\S+\.\S+
驗證網址:
"\S+://\S+\.\S+”
驗證郵政編碼:"\d{6}”
其他常用正則表達式:
表示0~9十個數字:"[0-9]”
表示任意個數字:"\d*”
表示中國大陸的固定電話號碼:"\d{3,4}-\d{7,8}”
驗證由兩位數字、一個連字符再加5位數字組成的ID號:"\d{2}-\d{5}”

②、自定義驗證控件(CustomValidator)
Default頁面:
復制代碼 代碼如下:
<asp:CustomValidator ID="CustomValidator1" runat="server" ErrorMessage="此用戶名已注冊過" 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;
}
}
}

通過自定義服務器端的函數代碼,與前台驗證控件關聯,形成一種假客戶端—當前頁面驗證的效果。
以上面前台驗證控件這段代碼為例:
ErrorMessage屬性表示當驗證不合法時,出現錯誤的信息;
ControlToValidate屬性表示需驗證的控件ID;
OnServerValidate屬性表示與自定義函數相關聯,以在服務器上執行驗證;

效果如下:

摘自 暗自在綻放
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved