ASP.NET 验证控件详解

WEB开发者特别是ASP开发者,一直对数据验证比较恼火,当你好不容易写出数据提交程序的主体以后,还不得不花大把时间去验证用户的每一个输入是否合法。如果开发者熟悉JavaScript或者VBScript,可以用这些脚本语言轻松实现验证,但是又要考虑用户浏览器是否支持这些脚本语言;如果对这些不是很熟悉或者想支持所有用户浏览器,就必须在ASP程序里面验证,但是这样验证就会增加服务器负担。现在,有了ASP.NET,你不但可以轻松的实现对用户输入的验证,而且,还可以选择验证在服务器端进行还是在客户端进行,再也不必考虑那么多了,程序员们可以将重要精力放在主程序的设计上了。

下面介绍ASP.NET中的六种验证控件:

一、RequiredFieldValidator(必须字段验证) 用于检查是否有输入值

控件使用的标准代码如下

1                     <tr>
2                         <td align="right" class="text">登录账号:</td>
3                         <td width="185px"><asp:textbox  CssClass="ip" runat="server" ID="userid"></asp:textbox></td>
4                          <td width="300px">
5                              <asp:RequiredFieldValidator ID="requireId" runat="server" 
6                                  ErrorMessage="输入不能为空" ControlToValidate="userid" Display="Static"></asp:RequiredFieldValidator>
7                         </td>
8                     </tr>

在代码中 有一个需要用户输入的textbox,我们通过RequiredFieldValidator控件来验证用户的输入是否为真;

在以上标准代码中:

ControlToValidate:表示要进行检查控件ID;

ErrorMessage:表示当检查不合法时,出现的错误信息;

Display: 表示错误信息的表示方式;(Static 表示错误信息在页面中占有肯定的位置;Dymatic表示控件错误信息出现时才占用页面控件;None表示错误出现时不显示,但是可以在ValidatorSummary中显示;

注意:以上代码以及下面要介绍的控件代码最好放入Form中, 如:<Form runat="server">其他代码</Form>  这样,Form在服务器端执行,提交才会有效;

二、CompareValidator(比较验证)控件

代码如下:

<asp:CompareValidator ID="comparepwd" runat="server" 
                                 ErrorMessage="两次输入密码不一致" ControlToCompare="userpwd" 
                                 ControlToValidate="surepwd" Display="Dynamic"></asp:CompareValidator>

ControlToCompare: 为要被比较的控件的ID (可以是第一次输入密码的那个控件的ID);

ControlToValidate: 进行比较的空间的ID (可以是重复密码的那个控件的ID);

其他属性和RequiredFieldValidator差不多。 

 

三、RangeValidator(范围验证)控件

验证输入是否在一定范围,范围用MaximumValue(最大)和MinimunVlaue来确定,标准代码如下:

<ASP:RangeValidator id="Vaidator_ID" Runat="Server" controlToValidate="要验证的控件ID" type="Integer"
             MinimumValue="最值" MaximumValue="最大值" errorMessage="错误信息" Display="Static|Dymatic|None"
/ASP:RangeValidator>

在以上代码中:

  用MinimumValue和MaximumValue来界定控件输入值得范围,用type来定义控件输入值的类型。

如可以用来验证用户输入的年龄是否合法等信息;

 

四、RegularExpresionValidator(正则表达式)控件

正则表达式验证控件的功能非常强大,你可以自己容易构造验证方式,我们先来看看标准代码:

<ASP:RegularExpressionValidator id="Validator_ID" RunAt="Server" ControlToValidate="要验证控件名"
                    ValidationExpression="正则表达式" errorMessage="错误信息" display="Static" >
</ASP:RegularExpressionValidator>

在以上标准代码中,ValidationExpression是重点,现在来看看它的构造

在ValidationExpression中,不同字符表示不同的含义 ;(正则表达是的内容还有待总结!!)

下面为两个常见的正则表达式:

 验证手机号:(\d{2,3}-){0,1}\d{11}

验证邮箱格式:\w+([-+.']\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*

 

五、ValidationSummary(验证总结)控件

该控件收集本页的所有验证错误信息,并可以将它们组织以后再显示出来。其标准代码如下:

<ASP:ValidationSummary id="Validator_ID" RunAT="Server" HeaderText="头信息" ShowSummary="True|False" DiaplayMode="List|BulletList|SingleParagraph" >
</ASP: ValidationSummary > 

在以上标准代码中,HeadText相当于表的HeadText,DisplayMode表示错误信息显示方式:List相当于HTML中的<BR>;BulletList相当于HTML中的<LI>;SingleParegraph表示错误信息之间不作如何分割

CustomValidator(自定义验证)控件

该控件用自定义的函数界定验证方式,其标准代码如下:

<ASP:CustomValidator id="Validator_ID" RunAt="Server" controlToValidate="要验证的控件" onServerValidateFunction="验证函数" errorMessage="错误信息" Display="Static|Dymatic|None" >
</ASP: CustomValidator >

以上代码中,用户必须定义一个函数来验证输入。

总结:以上,APS.NET的验证控件就介绍完了,希望在以后的编码过程中,这些控件能提高我们的工作效率!

 

 

 

 

 

 

 

 

 

posted @ 2013-05-16 15:25  Rampage_Pom  阅读(147)  评论(0)    收藏  举报