浅谈在ASP.NET中数据有效性校验的方法

2008-02-22 09:28:29来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

作为一名程序员,一定要对自己编写的程序的健壮性负责,因此数据的校验无论在商业逻辑还是系统实现都是必不可少的部分。

我这里总结了一种自认为比较不错的asp.net(C#)的数据校验方法,如大家探讨。

主要用Regex的IsMatch方法,在BusinessRule层进行校验数据的有效性,并将校验的方法作为BusinessRule层基类的一部分。

在WebUI层现实提示信息。

using System;
using System.Data;
using System.Text.RegularExpressions;
namespace Education.BusinessRules
{
/// <summary>
/// 商业规则层的基类
/// </summary>
public class BizObject
{
public const String REGEXP_IS_VALID_EMAIL = @"^\w ((-\w )|(\.\w ))*\@\w ((\.|-)\w )*\.\w $"; //电子邮件校验常量
public const String REGEXP_IS_VALID_URL = @"^http://([\w-] \.) [\w-] (/[\w- ./?%&=]*)?"; //网址校验常量
public const String REGEXP_IS_VALID_ZIP = @"\d{6}"; //邮编校验常量
public const String REGEXP_IS_VALID_SSN = @"\d{18}|\d{15}"; //身份证校验常量
public const String REGEXP_IS_VALID_INT = @"^\d{1,}$"; //整数校验常量
public const String REGEXP_IS_VALID_DEMICAL = @"^-?(0|\d )(\.\d )?$"; //数值校验常量 "
//日期校验常量
public const String REGEXP_IS_VALID_DATE = @"^(?:(?:(?:(?:1[6-9]|[2-9]\d)?(?:0[48]|[2468][048]|[13579][26])|(?:(?:16|[2468][048]|[3579][26])00)))(\/|-|\.)(?:0?2\1(?:29))$)|(?:(?:1[6-9]|[2-9]\d)?\d{2})(\/|-|\.)(?:(?:(?:0?[13578]|1[02])\2(?:31))|(?:(?:0?[1,3-9]|1[0-2])\2(29|30))|(?:(?:0?[1-9])|(?:1[0-2]))\2(?:0?[1-9]|1\d|2[0-8]))$";

public BizObject(){}

#region 校验字段是否为空 或 字段长度超长 方法

public string GetFieldTooLongError(string ErrorField,int maxlen)
{
return ErrorField "信息超长,请删减至" maxlen.ToString() "个字符!" ;
}

public string GetFieldNullError(string ErrorField)
{
return ErrorField "是必填项,不允许为空!" ;
}

public bool IsValidField(DataRow Row, String fieldName, int maxLen,string ErrorField ,bool AllowNull)
{
int i = (short)(Row[fieldName].ToString().Trim().Length);

if ( i < 1 && (!AllowNull))
{
Row.SetColumnError(fieldName, GetFieldNullError(ErrorField));
return false;
}
else if (i > maxLen )
{
Row.SetColumnError(fieldName, GetFieldTooLongError(ErrorField,maxLen));
return false;
}
return true;
}
#endregion

#region 校验 电子邮件 类型字段格式 方法

public string GetEmailFieldError(string ErrorField)
{
return ErrorField "格式不正确(a@b.c)!" ;
}
public bool IsValidEmail(DataRow Row, String fieldName,int maxLen ,string ErrorField,bool AllowNull)
{
int i = (short)(Row[fieldName].ToString().Trim().Length);

bool isValid = IsValidField(Row,fieldName, maxLen , ErrorField , AllowNull);

if ( isValid )
{
isValid = (new Regex(REGEXP_IS_VALID_EMAIL)).IsMatch(Row[fieldName].ToString());

if ( (!isValid) && (i > 0))
{
Row.SetColumnError(fieldName, GetEmailFieldError(ErrorField));
return false;
}
}
return true;
}
#endregion

#region 校验 邮编 类型字段格式 方法

public string GetZipFieldError(string ErrorField)
{
return ErrorField "格式不正确(157032)!" ;
}
public bool IsValidZip(DataRow Row, String fieldName,int maxLen ,string ErrorField,bool AllowNull)
{
int i = (short)(Row[fieldName].ToString().Trim().Length);

bool isValid = IsValidField(Row,fieldName, maxLen , ErrorField , AllowNull);

if ( isValid )
{
isValid = (new Regex(REGEXP_IS_VALID_ZIP)).IsMatch(Row[fieldName].ToString());

if ( (!isValid) && (i > 0))
{
Row.SetColumnError(fieldName, GetZipFieldError(ErrorField));
return false;
}
}
return true;
}
#endregion

#region 校验 身份证 类型字段格式 方法

public string GetSSNFieldError(string ErrorField)
{
return ErrorField "格式不正确(长度为15或18位)!" ;
}
public bool IsValidSSN(DataRow Row, String fieldName,int maxLen ,string ErrorField,bool AllowNull)
{
int i = (short)(Row[fieldName].ToString().Trim().Length);

bool isValid = IsValidField(Row,fieldName, maxLen , ErrorField , AllowNull);

if ( isValid )
{
isValid = (new Regex(REGEXP_IS_VALID_SSN)).IsMatch(Row[fieldName].ToString());

if ( (!isValid) && (i > 0))
{
Row.SetColumnError(fieldName, GetSSNFieldError(ErrorField));
return false;
}
}
return true;
}
#endregion

#region 校验 网址 类型字段格式 方法

public string GetUrlFieldError(string ErrorField)
{
return ErrorField "格式不正确(http://www.abc.com)!" ;

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:数据库连接字在Web.config里的用法

下一篇:ASP.Net中自定义Http处理及应用之HttpHandler篇