ASP.net的验证控件浅析
①、数据格式验证控件(RegularExpressionValidator)
通过自定义正则表达式,与需验证的控件进行模式匹配。
以前面这段代码为例:
ErrorMessage属性表示当验证不合法时,出现错误的信息;
ControlToValidate属性表示需验证的控件ID;
ValidationExpression属性指定为验证条件的正则表达式;
在这里贴上常用正则表达式字符及其含义:
同时,列举几个常用的正则表达式:(有些是我自己用过的,有些是网上找的资料)
②、自定义验证控件(CustomValidator)
Default页面:
Defalult.cs页面:
通过自定义服务器端的函数代码,与前台验证控件关联,形成一种假客户端―当前页面验证的效果。
以上面前台验证控件这段代码为例:
ErrorMessage属性表示当验证不合法时,出现错误的信息;
ControlToValidate属性表示需验证的控件ID;
OnServerValidate属性表示与自定义函数相关联,以在服务器上执行验证;
效果如下:
摘自 暗自在绽放
代码如下:
<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属性表示与自定义函数相关联,以在服务器上执行验证;
效果如下:
摘自 暗自在绽放
相关推荐
wangzhaotongalex 2020-10-20
rechanel 2020-11-16
cshanzhizi 2020-10-16
luofuIT成长记录 2020-09-22
taomengxing 2020-09-07
MaggieRose 2020-08-19
jyj00 2020-08-15
MaggieRose 2020-07-04
modaiairen 2020-06-28
ziggurat 2020-06-28
JnX 2020-06-27
jyj00 2020-06-26
山水沐光 2020-06-25
shqhope 2020-06-23
eroshn 2020-06-21
码墨 2020-06-16
wyq 2020-11-11
TLROJE 2020-10-26
风雨断肠人 2020-10-13