我用了兩種方法判斷,第一種方法是直接使用字符串判斷:
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次
[a-zA-Z] 指a-zA-Z中的任意一個字母,但只是一個,而不是多個
^[a-zA-Z]放在一起表示以字母開頭
/w 任意一個字母或數字或下劃線,也就是 A~Z,a~z,0~9,_ 中任意一個
* 表達式不出現或出現任意次
$ 與字符串結束的地方匹配,不匹配任何字符
這樣寫本身就不包含漢字在內的