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

ASP.NET
.NET中如何生成静态页
ASP.NET定制简单的错误处理页面
在客户端验证密码强度[2],兼容FireFox和IE
如何以及为何创建Search .NET版
ASP.NET十分有用的页面间传值方法
使用ASP.NET AJAX框架扩展HTML Map控件
AJAX使用技巧:如何处理书签和翻页按扭
.NET环境下几种不同的邮件发送解决方案
.NET vs J2EE——面对SOA的荒谬与误解
ASP.NET学习篇(1)——开篇
ASP.NET学习篇(2)——安装与配置
ASP.NET学习篇(3)——几个简单的ASP.ENT的例子
ASP.NET学习篇(4)——服务器端的控件
项目调试时出现用到的一个组件“访问被拒绝”的解决方法
ASP.NET中“找不到指定模块”的解决办法
采用Native 引导方式的.Net加密保护
“您无权查看该网页”的原因和解决方法
ASP.NET中Datagrid常见错误
编写ASP.NET应用程序的技巧
Scott Mitchell ASP.NET 2数据控件嵌套

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


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