当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > asp.net中数据校验部分的封装与应用

ASP.NET
基于C#的接口基础教程之五
基于C#的接口基础教程之六
ASP.NET中数据库的操作初步----增加、删除、修改
从Internet上抓取指定URL的源码的方案(C#)
对C#中正则表达式的一些解读和总结
简述c#中对字符串进行分割的几种方法
ASP.NET中的事务处理和异常处理
用ASP.NET/C#连接Access和SQL Server数据库
ASP.NET 2.0中层次数据的处理
ASP.NET 2.0服务器控件之客户端功能
asp.net2.0 URL重写以及urlMappings问题(1)
asp.net2.0 URL重写以及urlMappings问题(2)
再议ASP.NET DataGrid控件中的“添加新行”功能
建立个人知识引擎的重要性
解析.Net框架下的XML编程技术
ASP.NET--制作功能完善的安装程序
Asp.net直接保存文件到客户端
.Net中消除Dll中的dependency
ASP.NET页面事件:顺序与回传详解
在ASP.NET+ORACLE添加数据记录并让ID自动增量

ASP.NET 中的 asp.net中数据校验部分的封装与应用


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-23   浏览: 94 ::
收藏到网摘: n/a

我们的业务系统涉及到较多的表单编辑与校验,最简单的办法是使用asp.net自带的数据校验控件即可,但这样有以下3个问题:

1 校验控件要在设计时加入到表单上,并手工设置:数据类型,错误信息等属性,比较繁琐。

2 对于一个输入框,我们可能要检查多项,如:必填,必须是日期格式,并且要大于2007-1-1。这样就需要加入多个校验控件。

3 业务规则和表单绑定在一起,不利于维护和重用。

我们希望的校验功能是:

1 校验规则和表单脱离,表单上画好输入框即可,校验控件会在运行时,根据配置文件动态创建。

2 根据验证规则,生成默认的:不能为空,错误的数字类型,必须在1到100之间这样的提示信息。

3 灵活的验证规则表达式:如: range(1, 200) , >=0.5 , Mail(), Mobile()。目前不支持 and, or 这样的条件,但容易扩展。

为此我们封装了这部分的功能,使用时只要:

在xml文件中设置好:控件名称,数据类型,是否必填,验证表达式信息。

以下为引用的内容:

   <ValidateInfo>
      <ControlName>排口数量</ControlName>
      <DataType>Integer</DataType>
      <Require>true</Require>
      <Expression>range(1, 100)</Expression>/Files/BoKeRen/validatetest.rar
   </ValidateInfo>

在page的Page_Init事件中,调用类方法:

以下为引用的内容:

   ValidateHelper.LoadFromFile("数据校验_配置.xml") 即可。


类设计:

以下为引用的内容:

 // 配置信息类
 class ValidateInfo
 {
      public string ControlName;
      public ValidationDataType DataType;
      public string ErrorMessage;
      public bool Require;
      public string Expression;
 }
 
// 校验控件创建工厂
 public class ValidatorFactory
 {
  CreateRequiredFieldValidator();
  CreateDateTypeCheckValidator();
  CreateRangeValidator(string min, string max);
  CreateCompareValidator(ValidationCompareOperator oper, string valueToCompare);
  ...
 }
 
// 校验规则解析器,根据配置信息,创建校验控件
   public class ValidatorParser
   {
    Parse(ValidateInfo info, ValidatorFactory factory);
    ...
   }
  
// 读取配置信息,并绑定校验控件到表单
   public class ValidateHelper
   {
    LoadFromFile(Page page, string fileName)
   }