在项目中需要对用户输入的信息,以及一些方法生成的结果进行验证,一般在项目中较多的采用js插件或js来进行有关信息的校验,但是从项目安全性的角度进行考虑,可对系统进行js注入。

如果在后台对用户输入的信息进行验证会相对的安全,在出现信息验证不合法时,可以直接在程序中抛出异常,终止程序的运行。

现在提供几种较为常用的验证方法,可以减少在项目中开发时间和错误性:

1.判断域名:

///<summary>///普通的域名///</summary>///<paramname="value"></param>///<returns></returns>publicstaticboolIsCommonDomain(stringvalue){returnQuickValidate("^(www.)?(\\w+\\.){1,3}(org|org.cn|gov.cn|com|cn|net|cc)$",value.ToLower());}

2.检查一个字符串是否是纯数字构成的,一般用于查询字符串参数的有效性验证:

///<summary>///检查一个字符串是否是纯数字构成的,一般用于查询字符串参数的有效性验证。///</summary>///<paramname="value">需验证的字符串。</param>///<returns>是否合法的bool值。</returns>publicstaticboolIsNumeric(stringvalue){returnQuickValidate("^[-]?[1-9]*[0-9]*$",value);}

3.检查一个字符串是否是纯字母和数字构成的,一般用于查询字符串参数的有效性验证:

///<summary>///检查一个字符串是否是纯字母和数字构成的,一般用于查询字符串参数的有效性验证。///</summary>///<paramname="value">需验证的字符串。</param>///<returns>是否合法的bool值。</returns>publicstaticboolIsLetterOrNumber(stringvalue){returnQuickValidate("^[a-zA-Z0-9_]*$",value);}

4.判断是否是数字,包括小数和整数:

///<summary>///判断是否是数字,包括小数和整数。///</summary>///<paramname="value">需验证的字符串。</param>///<returns>是否合法的bool值。</returns>publicstaticboolIsNumber(stringvalue){returnQuickValidate("^(0|([1-9]+[0-9]*))(.[0-9]+)?$",value);}

5.快速验证一个字符串是否符合指定的正则表达式:

///<summary>///快速验证一个字符串是否符合指定的正则表达式。///</summary>///<paramname="express">正则表达式的内容。</param>///<paramname="value">需验证的字符串。</param>///<returns>是否合法的bool值。</returns>publicstaticboolQuickValidate(stringexpress,stringvalue){varmyRegex=newSystem.Text.RegularExpressions.Regex(express);returnvalue.Length!=0&&myRegex.IsMatch(value);}

6.判断一个字符串是否为邮件:

///<summary>///判断一个字符串是否为邮件///</summary>///<paramname="value"></param>///<returns></returns>publicstaticboolIsEmail(stringvalue){varregex=newSystem.Text.RegularExpressions.Regex(@"^\w+([-+.]\w+)*@(\w+([-.]\w+)*\.)+([a-zA-Z]+)+$",RegexOptions.IgnoreCase);returnregex.Match(value).Success;}

7.判断一个字符串是否为邮编:

///<summary>///判断一个字符串是否为邮编///</summary>///<paramname="value"></param>///<returns></returns>publicstaticboolIsZipCode(stringvalue){returnQuickValidate("^([0-9]{6})$",value);}

8.判断一个字符串是否为ID格式:

///<summary>///判断一个字符串是否为ID格式///</summary>///<paramname="value"></param>///<returns></returns>publicstaticboolIsIdCard(stringvalue){System.Text.RegularExpressions.Regexregex;string[]strArray;if((value.Length!=15)&&(value.Length!=0x12)){returnfalse;}if(value.Length==15){regex=newSystem.Text.RegularExpressions.Regex(@"^(\d{6})(\d{2})(\d{2})(\d{2})(\d{3})$");if(!regex.Match(value).Success){returnfalse;}strArray=regex.Split(value);try{vardateTime=newDateTime(int.Parse("19"+strArray[2]),int.Parse(strArray[3]),int.Parse(strArray[4]));returntrue;}catch{returnfalse;}}regex=newSystem.Text.RegularExpressions.Regex(@"^(\d{6})(\d{4})(\d{2})(\d{2})(\d{3})([0-9Xx])$");if(!regex.Match(value).Success){returnfalse;}strArray=regex.Split(value);try{vardateTime=newDateTime(int.Parse(strArray[2]),int.Parse(strArray[3]),int.Parse(strArray[4]));returntrue;}catch{returnfalse;}}

以上的验证方法采用方法封装,在实际的项目中,可以将所有的方法封装在类中,方法都定义为静态方法,在项目中可直接调用其中的验证方法,可以极大的提升项目的开发速度。