录入用户名经常都有这样子要求:首字符是字母,只允许录入字母、数字和下划线
我用了两种方法判断,第一种方法是直接使用字符串判断:
private bool CheckUserName(string s)
{
string str = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_0123456789";
if (str.Substring(0, 52).IndexOf(s[0]) == -1)
{
//首字符不是字母
return false;
}
else
{
foreach (char c in s)
{
if (str.IndexOf(c.ToString()) == -1)
{
return false;
}
}
}
return true;
}
第二种方法是使用正则表达式判断:
private bool CheckStr(string s)
{
System.Text.RegularExpressions.Regex reg = new System.Text.RegularExpressions.Regex(@"^[a-zA-Z][a-zA-Z0-9|_]{2,19}$");
if (reg.IsMatch(s))
{
return true;
}
else
{
return false;
}
}
在asp.net里,使用正则表达式还可以用验证控件:
<asp:RegularExpressionValidator ID="RegularExpressionValidator1" runat="server" ErrorMessage="*" C Validati></asp:RegularExpressionValidator>
下面解释一下我的正则表达式:^[a-zA-Z][a-zA-Z0-9|_]{2,19}$
^:匹配字符串的开头,在多行检索中,匹配一行的开头
$:匹配字符串的结尾,在多行检索中,匹配一行的结尾
|:选择,匹配的是该符号左边的子表达式或者右边的子表达式
{n, m}:匹配前一项至少n次,但是不能超过m次
{n, }:匹配前一项n次,或更多次
{n}:匹配前一项恰好n次
我用了两种方法判断,第一种方法是直接使用字符串判断:
private bool CheckUserName(string s)
{
string str = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_0123456789";
if (str.Substring(0, 52).IndexOf(s[0]) == -1)
{
//首字符不是字母
return false;
}
else
{
foreach (char c in s)
{
if (str.IndexOf(c.ToString()) == -1)
{
return false;
}
}
}
return true;
}
第二种方法是使用正则表达式判断:
private bool CheckStr(string s)
{
System.Text.RegularExpressions.Regex reg = new System.Text.RegularExpressions.Regex(@"^[a-zA-Z][a-zA-Z0-9|_]{2,19}$");
if (reg.IsMatch(s))
{
return true;
}
else
{
return false;
}
}
在asp.net里,使用正则表达式还可以用验证控件:
<asp:RegularExpressionValidator ID="RegularExpressionValidator1" runat="server" ErrorMessage="*" C Validati></asp:RegularExpressionValidator>
下面解释一下我的正则表达式:^[a-zA-Z][a-zA-Z0-9|_]{2,19}$
^:匹配字符串的开头,在多行检索中,匹配一行的开头
$:匹配字符串的结尾,在多行检索中,匹配一行的结尾
|:选择,匹配的是该符号左边的子表达式或者右边的子表达式
{n, m}:匹配前一项至少n次,但是不能超过m次
{n, }:匹配前一项n次,或更多次
{n}:匹配前一项恰好n次
****************************************8
^ 与字符串开始的地方匹配,不匹配任何字符
[a-zA-Z] 指a-zA-Z中的任意一个字母,但只是一个,而不是多个
^[a-zA-Z]放在一起表示以字母开头
/w 任意一个字母或数字或下划线,也就是 A~Z,a~z,0~9,_ 中任意一个
* 表达式不出现或出现任意次
$ 与字符串结束的地方匹配,不匹配任何字符
这样写本身就不包含汉字在内的
[a-zA-Z] 指a-zA-Z中的任意一个字母,但只是一个,而不是多个
^[a-zA-Z]放在一起表示以字母开头
/w 任意一个字母或数字或下划线,也就是 A~Z,a~z,0~9,_ 中任意一个
* 表达式不出现或出现任意次
$ 与字符串结束的地方匹配,不匹配任何字符
这样写本身就不包含汉字在内的