.Net项目中一些常用验证操作
在项目中需要对用户输入的信息,以及一些方法生成的结果进行验证,一般在项目中较多的采用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;
}
}
9.判断是不是纯中文:
///<summary>
///判断是不是纯中文
///</summary>
///<paramname="value"></param>
///<returns></returns>
publicstaticboolIsChinese(stringvalue)
{
varregex=newSystem.Text.RegularExpressions.Regex(@"^[\u4E00-\u9FA5\uF900-\uFA2D]+$",RegexOptions.IgnoreCase);
returnregex.Match(value).Success;
}
10.判断一个字符串是否为手机号码:
///<summary>
///判断一个字符串是否为手机号码
///</summary>
///<paramname="value"></param>
///<returns></returns>
publicstaticboolIsMobileNum(stringvalue)
{
varregex=newSystem.Text.RegularExpressions.Regex(@"^(13|15)\d{9}$",RegexOptions.IgnoreCase);
returnregex.Match(value).Success;
}
11.判断一个字符串是否为电话号码:
///<summary>
///判断一个字符串是否为电话号码
///</summary>
///<paramname="value"></param>
///<returns></returns>
publicstaticboolIsPhoneNum(stringvalue)
{
varregex=newSystem.Text.RegularExpressions.Regex(@"^(86)?(-)?(0\d{2,3})?(-)?(\d{7,8})(-)?(\d{3,5})?$",RegexOptions.IgnoreCase);
returnregex.Match(value).Success;
}
12.判断一个字符串是否为网址:
///<summary>
///判断一个字符串是否为网址
///</summary>
///<paramname="value"></param>
///<returns></returns>
publicstaticboolIsUrl(stringvalue)
{
varregex=newSystem.Text.RegularExpressions.Regex(@"(http://)?([\w-]+\.)*[\w-]+(/[\w-./?%&=]*)?",RegexOptions.IgnoreCase);
returnregex.Match(value).Success;
}
13.判断一个字符串是否为IP地址:
///<summary>
///判断一个字符串是否为IP地址
///</summary>
///<paramname="value"></param>
///<returns></returns>
publicstaticboolIsIp(stringvalue)
{
varregex=newSystem.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);
returnregex.Match(value).Success;
}
14.判断一个字符串是否为字母加数字:
///<summary>
///判断一个字符串是否为字母加数字
///Regex("[a-zA-Z0-9]?"
///</summary>
///<paramname="value"></param>
///<returns></returns>
publicstaticboolIsWordAndNum(stringvalue)
{
varregex=newSystem.Text.RegularExpressions.Regex("[a-zA-Z0-9]?");
returnregex.Match(value).Success;
}
以上的验证方法采用方法封装,在实际的项目中,可以将所有的方法封装在类中,方法都定义为静态方法,在项目中可直接调用其中的验证方法,可以极大的提升项目的开发速度。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。