配置struts应用[5]---struts-config.xml配置2

来源:互联网 发布:关于网络论文 编辑:程序博客网 时间:2024/05/17 04:58

<form-beans>元素

<form-beans>元素用来配置多个ActionForm Bean。<form-beans>元素包含零个,一个或多个<form-bean>子元素。每个<form-bean>又包含多个属性:

属性

描述

className

指定和<form-bean>元素对应的配置类,默认值为org.apache.struts.config.FormBeanConfig,如果在这里设置自定义的类,该类必须扩展FormBeanConfig类。

Name

指定该ActionForm Bean的唯一标识符,整个Struts框架用标识符来引用这个Bean,该属性是必须的。

Type

指定ActionForm类的完整名,该属性是必需的。(在配置type属性时,必须给出ActionForm类的完整类名,即包括类的包名。)

<form-beans>

    <form-bean name=”logonForm”

type=”addressbook.forms.LogonForm”/>

</form-beans>

使用动态ActionForm

ActionForm的缺点是对于大型的Struts应用,必须以编程的方式来创建大量的ActionForm类,如果HTML表单的字段发生变化,就必须修改并重新编译相关的ActionForm类,例如:如果在网页的表单中需要添加一个表项(例如在一个调查表单中添加一项以前没有想到的调查内容),则需要重新编写ActionForm中的属性项和方法,然后重新编译这个ActionForm。这样就给网站的维护带来了麻烦。因此引入动态的ActionForm类的概念。

1)配置动态ActionForm

动态ActionForm支持在Struts配置文件中完成ActionForm的全部配置,没有必要编写额外的程序来创建具体的ActionForm类,配置动态ActionForm类的方法为:在Struts配置文件中配置一个<form-bean>元素,将type属性设置为DynaActionForm或它的某个子类的全名。例如:

<form-beans>

    <form-bean

        name=”loginForm”

        type=”org.apache.struts.DynaActionForm”>//此语句识别表单是否为动态

    <!—配置动态ActionForm的属性-->

    <form-property

    name=”email”

    type=”java.lang.String”/>

<form-property

name=”password”

type=”java.lang.String”/>

 

    <!—也可以在此处初始化属性值-->

    <form-property

initial=”false”

name=”rememberMe”

type=”java.lang.Boolean”/>

    </form-bean>

</form-beans>

 

属性

描述

className

指定和<form-property>元素对应的配置类,默认值为org.apache.struts.config.FormPropertyConfig

Initial

以字符串的形式设置表单字段的初始值。如果没有设置该属性,则基本类型的表单字段的默认值为0,对象字段的表单字段的默认值为null

Name

指定字段的名字,该属性是必须的

Type

指定表单字段的类型,如果表单字段位java类,必须给出完整的类名,该属性是必须的。

<form-property>元素的属性表格

<form-property>元素是用来配置动态ActionForm的特有和必要元素。其中type用来指定属性类型,可以把动态ActionForm的属性设定为下列java类型:

java.lang.BigDecimal

java.lang.BigInteger

java.lang.Boolean

java.lang.Byte

java.lang.Character

java.lang.Class

java.lang.Double

java.lang.Float

java.lang.Integer

java.lang.Long

java.lang.Short

java.lang.String

java.sql.Date

java.sql.Time

java.sql.Timestamp

2)动态ActionForm的reset()方法

    DynaActionForm基类提供了initialize()方法,它把表单的所有属性恢复为默认值。表单属性默认值由<form-bean>的<form-property>子元素的initial属性来决定,如果没有设置默认值,则表单属性的默认值由java类型来自动决定。基本类型的表单字段的默认值为0,对象字段的表单字段的默认值为null。

    DynaActionForm基类的initialize()方法的代码如下:

    public void initialize(ActionMapping mapping){

        String name=mapping.getName();

        If(name==null){

            return;

        }

        FormBeanConfig config=

mapping.getModuleConfig().findFormBeanConfig(name);

        if(config==null) {

            return;

        }  

        FormPropertyConfig.props[]=config.findFormPropertyConfigs();

        for(int i=0;i<props.length;i++) {

            set(props[i].getName().props[i].initial());

        }

}

    DynaActionForm基类的reset()方法不执行任何操作,其代码如下:

    public void reset(ActionMapping mapping,HttpServletRequest request){

        ;//不做任何操作

}

如果希望Struts框架在每次把表单数据组装到动态ActionFrom中之前,现把所有的属性恢复为默认值,可以定义一个扩展DynaActionForm类的子类,然后覆盖其reset()方法,在reset()方法中只要调用initialize()方法即可,代码如下:

public class MyDynaActionForm extends DynaActionForm{

    ……//省略initialize()方法或其他方法的定义

    public void reset(ActionMapping mapping, ActionServletRequest request){

        initialize(mapping);//调用initialize()方法来实现属性的恢复默认值

    }

}

3)访问动态ActionForm

例如在(1)中定义的email属性,可以通过下列方法来访问动态ActionForm中的email属性,代码如下:

//get email property(读取form表单的email属性的值)

String email=(String)form.get(“email”);

//set email property value(设置form表单的email属性的值)

form.set(“email”,”zytom@163.com”);

4)动态ActionForm的表单验证

 DynaActionForm基类的validate()方法没有提供任何默认的验证行为,可以定义扩展DynaActionForm的子类,然后覆盖validate()方法,但是Struts的设计初衷是利用设置来代替繁琐的编程,因此程序编写就违背了这个初衷,因此开发者开发了另一种机制,即Validate框架完成验证,我们将在以后学习Validate框架的配置。

<global-exceptions>元素

<global-exceptions>元素用来配置异常处理。<global-exception>元素可以包含零个或多个<exception>子元素。

<exception>元素用来设置java异常和处理类异常org.apache.struts.action.ExceptionHandler之间的映射。因为如果将java异常或类异常之间显示给用户,则可能让用户感到迷惑,或者一些别有用心的人可以根据这些异常来获得一些不应该让用户知道的网站设计信息。

下表为<exception>元素的属性:

属性

描述

className

指定和exception元素对应的配置类,默认为org.apache.struts.config.ExceptionConfig

handler

指定异常处理类,默认值为org.apache.struts.action.ExcepionHandler

Key

指定在Resource Bundle中描述该异常类的消息key

Path

指定异常类发生时的转发路径

Scope

指定ActionMessages实例的存放范围,可选值包括request和session,此项的默认值为request

Type

指定所需处理的异常类的名字,此项是必须的

Bundle

指定Resource Bundle

实例:

<global-exceptions>

    <exception

key=”global.error.invalidlogin”

path=”/security/signin.jsp”

scope=”request”

type=”netstore.framework.exception.InvalidLoginException”/>

</global-exceptions>

原创粉丝点击