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

asp.net|数据

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

    我这里总结了一种自认为比较不错的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)!" ;
  }
  public bool IsValidUrl(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_URL)).IsMatch(Row[fieldName].ToString());
               
    if ( (!isValid) && (i > 0))
    {
     Row.SetColumnError(fieldName, GetUrlFieldError(ErrorField));
     return false;
    }
   }           
   return true;
  }
  #endregion

  #region 校验 日期 类型字段格式 方法

  public string GetDateFieldError(string ErrorField)
  {
   return ErrorField + "日期格式不正确!" ;
  }
  public bool IsValidDate(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_DATE)).IsMatch(Row[fieldName].ToString());
               
    if ( (!isValid) && (i > 0))
    {
     Row.SetColumnError(fieldName, GetDateFieldError(ErrorField));
     return false;
    }
   }           
   return true;
  }
  #endregion 

  #region 校验 数值 类型字段格式 方法
  //这也是个判断数值的办法
  private bool IsNumeric(string Value)
  {
   try
   {
    int i = int.Parse(Value);
    return true;
   }
   catch
   { return false; }
  }

  public string GetFieldNumberError(string ErrorField)
  { 
   return ErrorField + "必须是数字(例如:90)!" ;
  }

  public bool IsValidNumber(DataRow Row, String fieldName,string ErrorField,bool AllowNull)
  {
   int  i = (short)(Row[fieldName].ToString().Trim().Length);
  
   bool isValid = (new Regex(REGEXP_IS_VALID_DEMICAL)).IsMatch(Row[fieldName].ToString());

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

 }
}

 

//在继承了基类的BusinessRule中使用校验的方法
  /// <summary>
  /// 使用上面的方法对数据进行有效性校验
  /// </summary>
  /// <param name="Row">数据行</param>
  /// <returns>通过--true 不通过--false</returns> 
  public bool Validate(DataRow Row)
  {
   bool isValid;           
   Row.ClearErrors();              
   isValid   = IsValidField(Row, "name", 20 ,"姓名",false);     
   isValid  &= IsValidZip(Row, "zip", 6,"邮编",true);
   isValid  &= IsValidNumber(Row, "age","年龄",false);
   isValid  &= IsValidEmail(Row,"email",50,"电子邮件" ,true); 
   return isValid;
  }

//在WebUI中显示错误提示信息
/// <summary>
/// 显示提交数据返回的错误信息
/// </summary>
private void DisplayErrors()
{
 String  fieldErrors="";
 String  tmpfieldErrors="";

        DataRow Row = ds.Tables[0].Rows[0];

 foreach (DataColumn Column in ds.Tables[0].Columns)
 {   
  tmpfieldErrors = Row.GetColumnError(Column.ColumnName.ToString());
  if (tmpfieldErrors!="")
  {
   fieldErrors += "<li>"  + tmpfieldErrors + "<br>";
  }
 }
 //显示错误信息
 this.lblError.Text = fieldErrors;
}

时间: 2025-01-20 17:04:44

ASP.NET中数据有效性校验的方法的相关文章

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

asp.net|数据 作为一名程序员,一定要对自己编写的程序的健壮性负责,因此数据的校验无论在商业逻辑还是系统实现都是必不可少的部分. 我这里总结了一种自认为比较不错的asp.net(C#)的数据校验方法,如大家探讨. 主要用Regex的IsMatch方法,在BusinessRule层进行校验数据的有效性,并将校验的方法作为BusinessRule层基类的一部分. 在WebUI层现实提示信息. using System;using System.Data;using System.Text.Re

ASP.NET中几种加密方法

MD5的全称是Message-Digest Algorithm 5(信息-摘要算法),在90年代初由Mit Laboratory for Computer Science和Rsa data security inc的Ronald l. rivest开发出来,经md2.md3和md4发展而来.它的作用是让大容量信息在用数字签名软件签署私人密匙前被"压缩"成一种保密的格式(就是把一个任意长度的字节串变换成一定长的大整数).不管是md2.md4还是md5,它们都需要获得一个随机长度的信息并产

ASP.net中网站访问量统计方法代码_实用技巧

一.建立一个数据表IPStat用于存放用户信息 我在IPStat表中存放的用户信息只包括登录用户的IP(IP_Address),IP来源(IP_Src)和登录时间(IP_DateTime),些表的信息本人只保存一天的信息,如果要统计每个月的信息则要保存一个月.因为我不太懂对数据日志的操作,所以创建此表,所以说我笨吧,哈哈. 二.在Global.asax中获取用户信息 在Global.asax的Session_Start即新会话启用时获取有关的信息,同时在这里实现在线人数.访问总人数的增量统计,代

asp.net中调用存储过程的方法_实用技巧

本文实例讲述了asp.net中调用存储过程的方法.分享给大家供大家参考,具体如下: 一.建立并调用一个不带参数的存储过程如下: CREATE PROCEDURE 全部学生<dbo.selectUsers> AS SELECT * FROM 学生 GO EXEC 全部学生 建立并调用一个带参数的存储过程如下: CREATE PROCEDURE 学生查询1 @SNAME VARCHAR(8),@SDEPT VARCHAR(20) AS SELECT * FROM 学生 WHERE 姓名=@SNAM

ASP.NET中实现获取调用方法名_实用技巧

本文实例讲述了ASP.NET中实现获取调用方法名的技巧.分享给大家供大家参考.具体实现方法如下: 在写记录日志功能时,需要记录日志调用方所在的模块名.命名空间名.类名以及方法名,想到使用的是反射(涉及到反射请注意性能),但具体是哪一块儿还不了解,于是搜索,整理如下:   需要添加相应的命名空间: 复制代码 代码如下: using System; using System.Diagnostics; using System.Reflection; 如果仅是获取当前方法名,可以使用如下代码: 复制代

ASP: 浏览器中上载文件的方法与实现

浏览器 ---- 一.问题引入 ---- 在现在的管理信息系统中,比较先进的都已采用浏览器/服务器的模型,在这种模型中都要涉及到客户端与服务器端的信息交互问题,从服务器端到客户端的信息传递技术已经比较成熟,这里主要讨论从客户端到服务器端的文件上载问题,基于Microsoft的IE4.0.IIS4.0.ASP(Active Server Page)和标准HTML语言. ---- 二.实现方法 ---- 在ASP页面中,利用HTML中的Form元素来实现. ---- 在Form元素的语法中,EncT

ASP.NET中Server对象的方法

本文给大家简单介绍一下 ASP.NET 中的 Server 对象的方法,初学者可以当个参照表来用. urIEncode 将URL字符串编码,语法格式为: 以下是引用片段: UrlEncode(ByValStringAsString)AsString urIDecode 将编码后的URL字符串解码,语法格式为: 以下是引用片段: UrlDecode(ByValStringAsString)AsString MaDPath 取得文件的实际路径,语法格式为: 以下是引用片段: MapPath(ByVa

ASP.NET中使用Ajax的方法_实用技巧

$.ajax向普通页面发送get请求这是最简单的一种方式了,先简单了解jQuery ajax的语法,最常用的调用方式是这样:$.ajax({settings}); 有几个常用的setting,全部参数及其解释可以去jQuery官方API文档查询 1. type:请求方式 get/post2. url:请求的Uri3. async:请求是否为异步4. headers:自定义的header参数5. data:发往服务器的参数6. dataType:参数格式,常见的有string.json.xml等7

ASP.NET中单态类的方法并发访问的会有问题么?

问题描述 ImportsSystem.Data.OleDbPublicClassTestModulePrivateSharedunlockMLAsTestModule=NothingPrivateSharedReadOnlyobjAsObject=NewObjectPublicSharedFunctionGetInstance()AsTestModuleSyncLockobjIfunlockMLIsNothingThenunlockML=NewTestModuleEndIfReturnunloc