在项目中需要对用户输入的信息,以及一些方法生成的结果进行验证,一般在项目中较多的采用js插件或js来进行有关信息的校验,但是从项目安全性的角度进行考虑,可对系统进行js注入。
如果在后台对用户输入的信息进行验证会相对的安全,在出现信息验证不合法时,可以直接在程序中抛出异常,终止程序的运行。
现在提供几种较为常用的验证方法,可以减少在项目中开发时间和错误性:
1.判断域名:
/// <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.检查一个字符串是否是纯数字构成的,一般用于查询字符串参数的有效性验证:
/// <summary> /// 检查一个字符串是否是纯数字构成的,一般用于查询字符串参数的有效性验证。 /// </summary> /// <param name="value">需验证的字符串。</param> /// <returns>是否合法的bool值。</returns> public static bool IsNumeric(string value) { return QuickValidate("^[-]?[1-9]*[0-9]*$", value); }
3.检查一个字符串是否是纯字母和数字构成的,一般用于查询字符串参数的有效性验证:
/// <summary> /// 检查一个字符串是否是纯字母和数字构成的,一般用于查询字符串参数的有效性验证。 /// </summary> /// <param name="value">需验证的字符串。</param> /// <returns>是否合法的bool值。</returns> public static bool IsLetterOrNumber(string value) { return QuickValidate("^[a-zA-Z0-9_]*$", value); }
4.判断是否是数字,包括小数和整数:
/// <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.快速验证一个字符串是否符合指定的正则表达式:
/// <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); }
新闻热点
疑难解答
图片精选