在项目中需要对用户输入的信息,以及一些方法生成的结果进行验证,一般在项目中较多的采用js插件或js来进行有关信息的校验,但是从项目安全性的角度进行考虑,可对系统进行js注入。
如果在后台对用户输入的信息进行验证会相对的安全,在出现信息验证不合法时,可以直接在程序中抛出异常,终止程序的运行。
现在提供几种较为常用的验证方法,可以减少在项目中开发时间和错误性:
1.判断域名:
1
2
3
4
5
6
7
8
9
|
/// <summary>
/// 普通的域名
/// </summary>
/// <param name="value"></param>
/// <returns></returns>
public static bool IsCommonDomain( string value)
{
return QuickValidate( "^(www.)?(\\w+\\.){1,3}(org|org.cn|gov.cn|com|cn|net|cc)$" , value.ToLower());
}
|
2.检查一个字符串是否是纯数字构成的,一般用于查询字符串参数的有效性验证:
1
2
3
4
5
6
7
8
9
|
/// <summary>
/// 检查一个字符串是否是纯数字构成的,一般用于查询字符串参数的有效性验证。
/// </summary>
/// <param name="value">需验证的字符串。</param>
/// <returns>是否合法的bool值。</returns>
public static bool IsNumeric( string value)
{
return QuickValidate( "^[-]?[1-9]*[0-9]*$" , value);
}
|
3.检查一个字符串是否是纯字母和数字构成的,一般用于查询字符串参数的有效性验证:
1
2
3
4
5
6
7
8
9
|
/// <summary>
/// 检查一个字符串是否是纯字母和数字构成的,一般用于查询字符串参数的有效性验证。
/// </summary>
/// <param name="value">需验证的字符串。</param>
/// <returns>是否合法的bool值。</returns>
public static bool IsLetterOrNumber( string value)
{
return QuickValidate( "^[a-zA-Z0-9_]*$" , value);
}
|
4.判断是否是数字,包括小数和整数:
1
2
3
4
5
6
7
8
9
|
/// <summary>
/// 判断是否是数字,包括小数和整数。
/// </summary>
/// <param name="value">需验证的字符串。</param>
/// <returns>是否合法的bool值。</returns>
public static bool IsNumber( string value)
{
return QuickValidate( "^(0|([1-9]+[0-9]*))(.[0-9]+)?$" , value);
}
|
5.快速验证一个字符串是否符合指定的正则表达式:
1
2
3
4
5
6
7
8
9
10
11
|
/// <summary>
/// 快速验证一个字符串是否符合指定的正则表达式。
/// </summary>
/// <param name="express">正则表达式的内容。</param>
/// <param name="value">需验证的字符串。</param>
/// <returns>是否合法的bool值。</returns>
public static bool QuickValidate( string express, string value)
{
var myRegex = new System.Text.RegularExpressions.Regex(express);
return value.Length != 0 && myRegex.IsMatch(value);
}
|
6.判断一个字符串是否为邮件:
1
2
3
4
5
6
7
8
9
10
|
/// <summary>
/// 判断一个字符串是否为邮件
/// </summary>
/// <param name="value"></param>
/// <returns></returns>
public static bool IsEmail( string value)
{
var regex = new System.Text.RegularExpressions.Regex( @"^\w+([-+.]\w+)*@(\w+([-.]\w+)*\.)+([a-zA-Z]+)+$" , RegexOptions.IgnoreCase);
return regex.Match(value).Success;
}
|
7.判断一个字符串是否为邮编:
1
2
3
4
5
6
7
8
9
|
/// <summary>
/// 判断一个字符串是否为邮编
/// </summary>
/// <param name="value"></param>
/// <returns></returns>
public static bool IsZipCode( string value)
{
return QuickValidate( "^([0-9]{6})$" , value);
}
|
8.判断一个字符串是否为ID格式:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
/// <summary>
/// 判断一个字符串是否为ID格式
/// </summary>
/// <param name="value"></param>
/// <returns></returns>
public static bool IsIdCard( string value)
{
System.Text.RegularExpressions.Regex regex;
string [] strArray;
if ((value.Length != 15) && (value.Length != 0x12))
{
return false ;
}
if (value.Length == 15)
{
regex = new System.Text.RegularExpressions.Regex( @"^(\d{6})(\d{2})(\d{2})(\d{2})(\d{3})$" );
if (!regex.Match(value).Success)
{
return false ;
}
strArray = regex.Split(value);
try
{
var dateTime = new DateTime( int .Parse( "19" + strArray[2]), int .Parse(strArray[3]), int .Parse(strArray[4]));
return true ;
}
catch
{
return false ;
}
}
regex = new System.Text.RegularExpressions.Regex( @"^(\d{6})(\d{4})(\d{2})(\d{2})(\d{3})([0-9Xx])$" );
if (!regex.Match(value).Success)
{
return false ;
}
strArray = regex.Split(value);
try
{
var dateTime = new DateTime( int .Parse(strArray[2]), int .Parse(strArray[3]), int .Parse(strArray[4]));
return true ;
}
catch
{
return false ;
}
}
|
9.判断是不是纯中文:
1
2
3
4
5
6
7
8
9
10
|
/// <summary>
/// 判断是不是纯中文
/// </summary>
/// <param name="value"></param>
/// <returns></returns>
public static bool IsChinese( string value)
{
var regex = new System.Text.RegularExpressions.Regex( @"^[\u4E00-\u9FA5\uF900-\uFA2D]+$" , RegexOptions.IgnoreCase);
return regex.Match(value).Success;
}
|
10.判断一个字符串是否为手机号码:
1
2
3
4
5
6
7
8
9
10
|
/// <summary>
/// 判断一个字符串是否为手机号码
/// </summary>
/// <param name="value"></param>
/// <returns></returns>
public static bool IsMobileNum( string value)
{
var regex = new System.Text.RegularExpressions.Regex( @"^(13|15)\d{9}$" , RegexOptions.IgnoreCase);
return regex.Match(value).Success;
}
|
11.判断一个字符串是否为电话号码:
1
2
3
4
5
6
7
8
9
10
|
/// <summary>
/// 判断一个字符串是否为电话号码
/// </summary>
/// <param name="value"></param>
/// <returns></returns>
public static bool IsPhoneNum( string value)
{
var regex = new System.Text.RegularExpressions.Regex( @"^(86)?(-)?(0\d{2,3})?(-)?(\d{7,8})(-)?(\d{3,5})?$" , RegexOptions.IgnoreCase);
return regex.Match(value).Success;
}
|
12.判断一个字符串是否为网址:
1
2
3
4
5
6
7
8
9
10
|
/// <summary>
/// 判断一个字符串是否为网址
/// </summary>
/// <param name="value"></param>
/// <returns></returns>
public static bool IsUrl( string value)
{
var regex = new System.Text.RegularExpressions.Regex( @"(http://)?([\w-]+\.)*[\w-]+(/[\w- ./?%&=]*)?" , RegexOptions.IgnoreCase);
return regex.Match(value).Success;
}
|
13.判断一个字符串是否为IP地址:
1
2
3
4
5
6
7
8
9
10
|
/// <summary>
/// 判断一个字符串是否为IP地址
/// </summary>
/// <param name="value"></param>
/// <returns></returns>
public static bool IsIp( string value)
{
var regex = new System.Text.RegularExpressions.Regex( @"^(((2[0-4]{1}[0-9]{1})|(25[0-5]{1}))|(1[0-9]{2})|([1-9]{1}[0-9]{1})|([0-9]{1})).(((2[0-4]{1}[0-9]{1})|(25[0-5]{1}))|(1[0-9]{2})|([1-9]{1}[0-9]{1})|([0-9]{1})).(((2[0-4]{1}[0-9]{1})|(25[0-5]{1}))|(1[0-9]{2})|([1-9]{1}[0-9]{1})|([0-9]{1})).(((2[0-4]{1}[0-9]{1})|(25[0-5]{1}))|(1[0-9]{2})|([1-9]{1}[0-9]{1})|([0-9]{1}))$" , RegexOptions.IgnoreCase);
return regex.Match(value).Success;
}
|
14.判断一个字符串是否为字母加数字:
1
2
3
4
5
6
7
8
9
10
11
|
/// <summary>
/// 判断一个字符串是否为字母加数字
/// Regex("[a-zA-Z0-9]?"
/// </summary>
/// <param name="value"></param>
/// <returns></returns>
public static bool IsWordAndNum( string value)
{
var regex = new System.Text.RegularExpressions.Regex( "[a-zA-Z0-9]?" );
return regex.Match(value).Success;
}
|
以上的验证方法采用方法封装,在实际的项目中,可以将所有的方法封装在类中,方法都定义为静态方法,在项目中可直接调用其中的验证方法,可以极大的提升项目的开发速度。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。