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

ASP.NET
.NET:InTheHand提供的类操作SMS
捕捉WPF应用程序中XAML代码解析异常
学习asp.net之SQL语句查询效率和安全性
一个不被flash、select、activex遮挡的、跨frame的无限分级菜单
探索 ASP.NET Futures
MSDN Visual系列:创建SharePoint Services解决方案包
.net中如何给数据表实体类赋值的方法
关于C#静态构造函数的几点说明
经典教程:用.net动态创建类的实例
ASP.NET 遍历配置文件的连接字符串
ASP.Net中利用CSS实现多界面两法
ASP.NET生成静态HTML页面并分别按年月目录存放
如何在ASP.net(C#)下操作XML文件
技巧应用:ASP.Net中的MD5加密
三层架构各层间的访问过程
asp.net初学者:petshop4.0设计说明
asp.net利用RAR实现文件压缩解压缩
.NET2.0抓取网页全部链接
给初学.net的您几点建议
如何实现ASP.NET网站个性化

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-23   浏览: 100 ::
收藏到网摘: 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)
   }