JAVA流通桥

JAVA启发者

统计

留言簿(3)

AJAX相关网址

Eclipse相关网址

Hibernate

java相关网址

LINUX相关网址

webwork相关网址

友好链接

阅读排行榜

评论排行榜

验证框架

验证框架

WebWork提供了在Action执行之前,对输入数据的验证功能,它使用了其核心XWork的验证框架。提供了如下功能:

1、 可配置的验证文件。它的验证文件是一个独立的XML配置文件,对验证的添加、修改只需更改配置文件,无需编译任何的Class

2、 验证文件和被验证的对象完全解藕。验证对象是普通的JavaBean就可以了(可以是FormBean、域对象等),它们不需实现任何额外的方法或继承额外的类。

3、 多种不同的验证方式。因为它验证功能是可以继承的,所以可以用多种不同的方式指定验证文件,比如:通过父类的Action、通过Action、通过Action的方法、通过Action所使用的对象,等等。

4、 强大的表达式验证。它使用了OGNL的表达式语言,提供强大的表达式验证功能。

5、 同时支持服务器端和客户端验证。

为用户注册添加验证功能

下面我们来看看如何为用户注册添加验证功能:

1、 注册我们的验证类型

WebWork为不同的验证要求提供不同的验证类型。一个验证类型,一般是有一个类来提供。这个类必须实现接口:com.opensymphony.xwork.validator.Validator,但我们在写自己的验证类型时,无需直接实现Validator接口,它有抽象类可供直接使用如ValidatorSupportFieldValidatorSupport等。

验证类型在使用之前,必须要在ValidatorFactorycom.opensymphony.xwork.validator. ValidatorFactory)中注册。可以有二种方法实现验证类型的注册。一、写程序代码进行注册,它使用ValidatorFactory类的静态方法:registerValidator(String name, String className)二、使用配置文件validators.xml进行注册,要求把文件validators.xml放到ClassPath的跟目录中(/WEB-INF/classes)。但在实际开发中,一般都使用第二中注册方法。我们的验证类型注册如下:

<validators>

    <validator name="required" class="com.opensymphony.xwork.validator.validators.RequiredFieldValidator"/>

    <validator name="requiredstring" class="com.opensymphony.xwork.validator.validators.RequiredStringValidator"/>

    <validator name="int" class="com.opensymphony.xwork.validator.validators.IntRangeFieldValidator"/>

    <validator name="date" class="com.opensymphony.xwork.validator.validators.DateRangeFieldValidator"/>

    <validator name="expression" class="com.opensymphony.xwork.validator.validators.ExpressionValidator"/>

    <validator name="fieldexpression" class="com.opensymphony.xwork.validator.validators.FieldExpressionValidator"/>

    <validator name="email" class="com.opensymphony.xwork.validator.validators.EmailValidator"/>

    <validator name="url" class="com.opensymphony.xwork.validator.validators.URLValidator"/>

    <validator name="visitor" class="com.opensymphony.xwork.validator.validators.VisitorFieldValidator"/>

    <validator name="conversion" class="com.opensymphony.xwork.validator.validators.ConversionErrorFieldValidator"/>

    <validator name="stringlength" class="com.opensymphony.xwork.validator.validators.StringLengthFieldValidator"/>

</validators>

注册验证类型的配置文件非常简单。它使用标签<validator>提供名-值对的形式注册。这样我们的验证文件就可以直接引用它的名字。

2、 开启Action的验证功能

 如果Action要使用验证框架的验证功能,它必须在配置文件中指定拦截器“validation”,它的定义如下:

<interceptor name="validation" class="com.opensymphony.xwork.validator.ValidationInterceptor"/>

我们的验证文件必须以ActionName-validation.xml格式命名,它必须被放置到与这个Action相同的包中。你也可以为这个Action通过别名的方式指定验证文件,它的命名格式为:ActionName-aliasname-validation.xml。“ActionName ”是我们Action的类名;“aliasname”是我们在配置文件(xwork.xml)中定义这个Action所用到的名称。这样,同一个Action类,在配置文件中的不同定义就可以对应不同的验证文件。验证框架也会根据Action的继承结构去查找Action的父类验证文件,如果找到它会去执行这个父类的验证。

 

3、 实现我们的验证文件:RegisterActionSupport-validation.xml

<!DOCTYPE validators PUBLIC "-//OpenSymphony Group//XWork Validator 1.0//EN" "http://www.opensymphony.com/xwork/xwork-validator-1.0.dtd">

<validators>

    <field name="user.username">

    <field-validator type="requiredstring">

            <message>You must enter a value for username.</message>

        </field-validator>

    </field>

    <field name="user.password">

    <field-validator type="requiredstring">

            <message>You must enter a value for password.</message>

        </field-validator>

        <field-validator type="fieldexpression">

            <param name="expression">user.password == verifyPassword</param>

            <message>Passwords don't match.</message>

        </field-validator>

    </field>

    <field name="user.email">

    <field-validator type="email">

            <message>You must enter a valid email.</message>

        </field-validator>

    </field>

    <field name="user.age">

    <field-validator type="int">

            <param name="min">6</param>

            <param name="max">100</param>

            <message>Age must be between ${min} and ${max}, current value is ${user.age}.</message>

        </field-validator>

    </field>

</validators>

说明:

1)、<field>标签代表一个字段,它的属性“name”和页面输入框的“name”属性必需完全一致,其实它也就是我们的表达式语言。

2)、<field-validator>标签定义我们的验证规则,type属性的值就是就是我们前面定义的验证类型。

3)、验证文件中,字段的数据是通过表达式语言从我们的值堆栈(OgnlValueStack)中取得,一般是ActionModel对象。例如:我们的字段“user.age”,它会通过ActiongetUser().getAge()来取得用户输入的年龄,再来根据验证的类型“int”和最大值最小值的参数来判断输入的数据是否能通过验证。

4)、不管验证是否通过,我们的Action都会执行,但如果验证没有通过,它不会调用Actionexecute()方法。

 

4、 显示Action的验证错误信息

如果用户输入的数据验证没有通过,我们需重新返回输入页面,并给出错误信息提示。拦截器栈“validationWorkflowStack”为我们实现了这个功能。它首先验证用户输入的数据,如果验证没有通过将不执行我们Actionexecute()方法,而是将请求重新返回到输入页面。

我们的xwork.xml配置文件如下:

<action name="registerSupport" class="com.test.RegisterActionSupport" >

           <result name="success" type="dispatcher">

              <param name="location">/registerResult.vm</param>

           </result>

           <result name="input" type="dispatcher">

              <param name="location">/registerSupport.vm</param>

           </result>

           <interceptor-ref name="validationWorkflowStack"/>

       </action>

 

通过接口ValidationAware我们可以获得类级别或字段级别的验证错误信息,这个错误信息也就是我们验证文件中<message>标签里的数据。ActionSupport类已实现了此接口,这样在应用中我们的Action只要继承ActionSupport类就可以了。RegisterActionSupport.java代码如下:

package com.test;

 

import com.opensymphony.xwork.ActionSupport;

 

public class RegisterActionSupport extends ActionSupport {

 

    private User user= new User();

    private String verifyPassword;

   

    public User getUser(){

       return this.user;

    }

   

    public String execute(){

       //在这里调用用户注册的业务逻辑,比如:将注册信息存储到数据库

       return SUCCESS;

    }

 

    public String getVerifyPassword(){

       return this.verifyPassword;

    }

   

    public void setVerifyPassword(String verPassword){

       this.verifyPassword = verPassword;

    }

}

我们WebWorkUI标签库直接提供了验证错误信息显示功能。如果字段级别的验证没有通过,它会在输入框上方显示验证文件定义的错误提示信息。我们将用户输入的页面更改如下:

registerSupport.vm

<html>

<head>

<title>WebWork Register - Example 4</title>

<meta name="help-path" content="/help/help5.html"/>

</head>

<body>

<p>Custom Component Example:</p>

 

<table border=0 width=97%>

<tr><td align="left">

    #bodytag (form "name='test'" "action='/registerSupport.action'" "method='POST'")

            #tag(textfield "label='Username'" "name='user.username'" "required='true'")

            #tag(textfield "label='Password'" "name='user.password'" "required='true'")

            #tag(textfield "label='VerifyPassword'" "name='verifyPassword'" "required='true'")

            #tag(textfield "label='Email'" "name='user.email'" "required='true'")

            #tag(textfield "label='Age'" "name='user.age'" "required='true'")

            #tag(submit value="'Submit'")

     #end

</td></tr>

</table>

<br/>

</body>

</html>

 

我们上面的相应结果文件registerResult.vm为:

<html>

<head><title>WebWork Register - Example 4 - Register result</title></head>

<body>

    <table border=0 width=97%>

        <tr>

            <td align="left">

            Congratulation,your register success!<p>

            Username:$!user.username<br>

            Password:$!user.password<br>

            Email:$!user.email<br>

            Age:$!user.age<br>

            </td>

        </tr>

    </table>

</body>

</html>

 

我们上面的例子使用的是服务器端验证。

posted on 2007-04-12 17:29 朱岩 阅读(267) 评论(0)  编辑  收藏 所属分类: webwork文章


只有注册用户登录后才能发表评论。


网站导航: