ASP.NET数据验证控件CustomValidator的使用浅析

ASP.NET数据验证控件的强大是因为在ASP中进行表单数据验证时,通常开发者必须自己编写一套验证的规则,然后自己将这些代码拷贝到ASP代码中对表单进行验证。这样进行验证的方式实在不太方便,幸运的是,ASP.NET解决了这个问题,这就是数据验证Web控件。

目前创新互联建站已为千余家的企业提供了网站建设、域名、雅安服务器托管、网站托管维护、企业网站设计、白山网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。

ASP.NET数据验证控件CustomValidator控件概述

简单地使用前面提到的前四个数据验证控件,就可以实现我们一般开发的大部分数据表单的验证要求。然而,有时候我们需要验证一些比较复杂的表单。想像一下,我们有一个比较复杂的调查表,该调查表包含一个有很多单选按钮和多选按钮的表单,一些多选按钮和个人的爱好相对应,比如游泳、体育、阅读等,调查表希望被调查人选择自己的所有爱好。在这些选项下面,提示如下文字:“如果你提示有体育和游泳两种爱好,请选择您什么时候开始学习游泳”,在这些文字下方放置一些标识年龄段的单选按钮,这些按钮是否有效取决于我们在前面提到的多选按钮的选择情况。在以上的验证情况中,我们就要使用到CustomValidator数据验证控件。

在所有的ASP.NET数据验证控件中,都有一个“ControlToValidate”的控件属性需要设置,这个属性用来指定表单中需要验证的表单项。在CustomValidator数据验证控件中,需要做以下事情:

1. 读取需要CustomValidator验证的表单项值;

2. 执行验证操作;

3. 决定被验证表单项是否符合验证要求。

在其他内建控件中,以上步骤用户是不知道也不要理睬的,但是,在使用CustomValidator的时候,我们需要自己动手实现以上步骤。为了实现以上步骤,我们需要编写一个服务器端数据验证函数,该函数的样式如下:

 
 
 
  1. Sub FunctionName(sender as Object, args as ServerValidateEventArgs)  
  2.  
  3. ……  
  4.  
  5. End Sub 

注意以上函数的args参数,它是FunctionName函数的第二个参数,这个参数有以下两个属性:

1. Value:被验证数据表单的值。

2. IsValid:验证是否通过。如果通过,IsValid的值是True; 如果没有通过,其值为False。

在使用CustomValidator的时候,我们不但要设置“ControlToValidate”属性,我们还必须设置OnServerValidate事件来处理服务器端的数据验证动作。

建立一个简单的ASP.NET数据验证控件CustomValidator

假设现在建立一个与数学有关的网站,在这个网站,我们要求浏览者提供自己喜欢的质数,以此来提高我们网站的访问量。在ASP.NET中,没有一个现成的可以专门验证质数的服务器端数据验证控件,这样,我们就有必要用到CustomValidator控件。

以下例子用来验证用户输入的数是不是质数。在这个表单中,有一个用户输入数据的TextBox控件和一个Button控件,还有用于验证是不是质数的CustomValidator控件,和两个用于保证用户输入为正数的CompareValidator控件。

 
 
 
  1. ﹤ script language=“vb” runat=“server” ﹥  
  2. Sub btnSubmit_Click(sender as Object, e as EventArgs)  
  3. If Page.IsValid then  
  4.   Response.Write(“﹤ font color=““red””﹥  
  5.   ﹤ i﹥”& txtPrimeNumber.Text & “is, indeed, a good prime number.  
  6.   ﹤  /i﹥﹤  /font﹥”)  
  7. Else  
  8. Response.Write(“﹤ font color=““red””﹥  
  9.  ﹤ i﹥” & txtPrimeNumber.Text & “is ﹤ b﹥not﹤ /b﹥   
  10.  a prime number.﹤ /i﹥﹤ /font﹥”)  
  11. End If  
  12.   End Sub  
  13.   Sub PrimeNumberCheck(sender as Object, args as 
  14.   ServerValidateEventArgs)  
  15. Dim iPrime as Integer = Cint(args.Value),  
  16.  iLoop as Integer, iSqrt as Integer = CInt(Math.Sqrt(iPrime))  
  17. For iLoop = 2 to iSqrt  
  18.   If iPrime mod iLoop = 0 then  
  19. args.IsValid = False  
  20. Exit Sub  
  21.   End If  
  22. Next  
  23. args.IsValid = True  
  24.   End Sub  
  25. ﹤ /script﹥  
  26. ﹤ form method=“post” runat=“server”﹥  
  27.   Enter your favorite prime number:  
  28. ﹤ asp:textbox id=“txtPrimeNumber” runat=“server” /﹥  
  29. ﹤ %-- 建立CustomValidator 控件 --%﹥  
  30.   ﹤ asp:CustomValidator runat=“server”   
  31. id=“custPrimeCheck”  
  32. ControlToValidate=“txtPrimeNumber”  
  33. OnServerValidate=“PrimeNumberCheck”  
  34. ErrorMessage=“Invalid Prime Number”/﹥  
  35. ﹤ %-- 建立两个CompareValidator控件:***个保证输入为数字;  
  36. 第二个保证输入为正数 --%﹥  
  37.   ﹤ asp:CompareValidator runat=“server”  
  38.   id=“compPrimeNumber”Operator=“DataTypeCheck”  
  39.   Type=“Integer”  
  40.   Display=“Dynamic” ControlToValidate=  
  41.   “txtPrimeNumber”ErrorMessage =  
  42.   “You must enter an integer value.”/﹥  
  43.   ﹤ asp:CompareValidator runat=“server”   
  44.   id=“compPrimeNumberPositive”Operator=“GreaterThan”  
  45.   Type=“Integer”  
  46.   Display=“Dynamic” ValueToCompare=“0”  
  47.   ControlToValidate=“txtPrimeNumber”  
  48.   ErrorMessage =“You must enter a value   
  49.   greater than zero.”/﹥  
  50.   ﹤ p﹥﹤ asp:button id=“btnSubmit” runat=  
  51.   “server”OnClick=“btnSubmit_Click” Text=“Submit” /﹥  
  52. ﹤ /form﹥ 

如果对判定质数不是太熟悉,可能对于以上的PrimeNumberCheck事件处理感觉比较迷惑。首先,将用户在txtPrimeNumber输入的数据通过事件的args.value传送给txtPrimeNumber,然后,将用户的输入开平方根,再将用户输入的数字除以从2到刚才算出的平方根之间的每一个数字。如果出现结果为零的情况,说明用户输入的数字不是质数,设置args.isValid为False; 如果全部为零,说明用户输入合法,设置args.isValid为True。

ASP.NET数据验证控件之客户端验证

ASP.NET内建数据验证控件的一大特点就是它们的所有验证都是在客户端进行的,不需经过服务器端,而CustomValidator控件的错误验证完全是通过服务器端实现的。必须意识到的一点是,不管是否通过客户端实现数据验证,服务器端的数据验证是一定会产生的。增加客户端验证的功能,只是让我们的数据验证控件更加友好。

为了实现客户端验证的功能,我们必须使用JavaScript或者VBScript写一个脚本函数,因为VBScript只支持IE浏览器,因此,这里我们采用JavaScript来编写这个函数:

 
 
 
  1. ﹤ script language=“JavaScript” ﹥  
  2. ﹤ !--  
  3.   function CheckPrime(sender, args)  
  4.   { var iPrime = parseInt(args.Value);  
  5. var iSqrt = parseInt(Math.sqrt(iPrime));  
  6. for (var iLoop=2; iLoop﹤ =iSqrt; iLoop++)  
  7.   if (iPrime % iLoop == 0)   
  8.   { args.IsValid = false;  
  9.  return;  
  10.   }  
  11.   args.IsValid = true;  
  12.   }  
  13. // --﹥  
  14. ﹤ /script ﹥ 

在这个例子里面,我们输入数字6,然后按“Tab”按钮。在高版本的浏览器里面,我们将看到来自CustomValidator控件的错误信息,这样,我们的CustomValidator控件也就有了客户端验证功能。在以上代码中,可能已经注意到我们并没有定义数据sender和args的类型,因为在脚本语言中,是没有严格的数据类型定义的。

为了实现客户端数据验证,惟一要做的就是在CustomValidator控件定义中加入以下语句:ClientValidationFunction=“CheckPrime”,这里,其实就是指定自定义验证控件的客户端验证函数。在这个例子里,前面定义的“CheckPrime”函数就是客户端验证函数。

ASP.NET数据验证控件CustomValidator的使用总结

上面我们介绍了ASP.NET中几乎是功能最灵活的数据验证控件CustomValidator的使用,介绍了CustomValidator控件的服务器端验证和客户端验证的实现。尽管在实际的开发工作中,可能我们使用ASP.NET的内置数据验证控件几乎完全可以满足我们的开发要求,但是若能了解CustomValidator控件的使用和特点将会更有利于解决在工作中碰到的数据验证问题。

ASP.NET数据验证控件CustomValidator的使用的基本情况就向你介绍到这里,希望对你有所帮助。

【编辑推荐】

  1. 有关ASP.NET代码分离的一些讨论
  2. ASP.NET代码分离使用的一点体会
  3. ASP.NET数据验证技术研究详解
  4. ASP.NET代码分离之网站建设应用浅析
  5. ASP.NET代码优化浅析

分享文章:ASP.NET数据验证控件CustomValidator的使用浅析
网页路径:http://www.shufengxianlan.com/qtweb/news5/180705.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联