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

ASP.NET
GridView添加删除按钮终极办法
AjaxPro让.NET的AjaxPro变得简单
c# 实现Word联接Excel的MailMerge功能
解开Ajax技术中的达芬奇密码
专家讲解用.NET编写串口程序的一点心得
利用AJAX和ASP.NET实现简单聊天室
如何快速捕获.NET代码中隐藏的BUG
动态网页原理/.net面面观
从N层到.NET详细剖析原理(2)
从N层到.NET详细剖析原理(1)
ASP.NET效率陷阱之——Attributes
在ASP.NET 2.0中建立站点导航层次(5)
在ASP.NET 2.0中建立站点导航层次(4)
在ASP.NET 2.0中建立站点导航层次(3)
在ASP.NET 2.0中建立站点导航层次(2)
在ASP.NET 2.0中建立站点导航层次(1)
动态网站Web开发PHP、ASP还是ASP.NET(2)
动态网站Web开发PHP、ASP还是ASP.NET(1)
让Apache支持ASP.NET-Apache,ASP.NET
.Net下的数据备份和还原

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


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