1、<struts-config> 元素
<struts-cofnig> 元素是 Struts 配置文件的根元素。<struts-config> 元素有 8 个子元素。在 Struts 配置文件中,必须按照它的 DTD 指定的先后顺序来配置 <struts-config> 元素的各个子元素,如果颠倒了这些子元素在配置文件中的顺序,在 Struts 应用启动时就会生成 XML 解析错误。
它的DTD定义如下:
<!ELEMENT struts-config(
data-sources?,form-beans?,global-exception?,global-forwards?,action-mappings?,controller?,message-resources*,plug-in*)
)>
配置时要按照上面的顺序。
2、 <form-beans> 元素
属性 | 描述 |
className | 指定和 <form-bean> 元素对应的配置类,默认值为 org.apache.struts.config.FormBeanConfig 。如果在这里设置自定义的类,该类必须扩展 FormBeanConfig 类 |
name | 指定该 ActionForm Bean 的唯一标识符,整个 Struts 框架用该标识符来引用这个 bean 。该属性是必需的。 |
type | 指定 ActionForm 类的完整类名(类的包名也包含在内),该属性是必需的 |
<form-beans >
<form-bean name="HelloForm" type="com.yourcompany.struts.form.HelloForm" />
</form-beans>
如果配置动态 ActionForm Bean ,还必须配置 <form-bean> 元素的 <form-property> 子元素。 <form-property> 元素用来指定表单字段,它有四个属性。
属性 | 描述 |
className | 指定和 <form-property> 元素对应的配置类,默认值为 org.apache.struts.config.FormPropertyConfig |
initial | 以字符串的形式设置表单字段的初始值。如果没有设置该属性,则基本类型的表单字段的默认值为 0 ,对象类型的表单字段的默认值为 null |
name | 指定表单字段的名字。该属性是必需的 |
type | 指定表单字段的类型。如果表单资源为 Java 类,必须给出完整的类名。该属性是必需的。 |
<form-beans >
<form-bean name="HelloForm" type="com.yourcompany.struts.form.HelloForm" />
<form-bean name="userForm" type="org.apache.struts.DynaActionForm">
<form-property name="firstName" type="java.long.String"></form-property>
<form-property name="lastName" type="java.long.String"></form-property>
<form-property name="age" type="java.lang.Integer" initial="18"></form-property>
</form-bean>
</form-beans>
3、<global-exceptions> 元素
属性 | 描述 |
className | 指定和 <exception> 元素对应的配置类。默认值为 org.apache.struts.config.ExceptionConfig |
handler | 指定异常处理类。默认值为 org.apache.struts.action.ExceptionHandler |
key | 指定在 Resource Bundle 中描述该异常的消息 key |
path | 指定当异常发生时的转发路径 |
scope | 指定 ActionMessages 实例的存放范围,可选值包括 request 和 session ,此项的默认值为 request |
type | 指定所需处理的异常类的名字。此项是必需的 |
bundle | 指定 Resource Bundle |
<global-exception>
<exception
key="global.error.invalidlogin"
path="/security/signin.jsp"
scope="request"
type="netstore.framework.exception.InvalidLoginException"
/>
</global-exception>
4、 <global-forwards> 元素
属性 | 描述 |
className | 和 <forward> 元素对应的配置类,默认值为 org.apache.struts.action.ActionForard |
contextRelative | 如果此项为 true ,表示当 path 属性以“ / ”开头时,给出的是相对于当前上下文的 URL 。此项的默认值为 false |
name | 转发路径的逻辑名。此项是必需的 |
path | 指定转发或重定向的 URL 。此项是必需的,必需以“ / ”开头。当 contextRelative 属性为 false 时,表示 URL 路径相对于当前应用 (application-relative) ;当 contextRelative 属性为 true 时,表示 URL 路径相对于当前上下文 (context-relative) |
redirect | 当此项为 true 时,表示执行重定向操作;当此项为 false 时,表示执行请求转发操作。此项默认值为 false |
例如:
<global-forwards>
<forward name="forward1" path="/Action1.do"></forward>
<forward name="forward2" path="/JSP2.jsp"></forward>
</global-forwards>
如果JSP1.jsp把请求转发给Action1可以<html:link forward="forward1">/或者 <logic:forward name="forward1"/>
如果Action1的excecute()方法把请求转发给JSP2.jsp的话可以这样:return(mapping.findForward("forward2"));
5、<action-mappings> 元素
属性 | 描述 |
attribute | 设置和 Action 关联的 ActionForm Bean 在 request 或 session 范围内的属性 key 。例如,假定 Form Bean 存在于 request 范围内,并且此项为“ myBean ”,那么 request.getAttribute(“MyBean”) 就可以返回该 Bean 的实例。此项为可选项。 |
className | 和 <action> 元素对应的配置元素。默认值为 org.apache.struts.action.ActionMapping |
forward | 指定转发的 URL 路径 |
include | 指定包含的 URL 路径 |
input | 指定包含输入表单的 URL 路径。当表单验证失败时,将把请求转发到该 URL |
name | 指定和该 Action 关联的 ActionForm Bean 的名字。该名字必需在 <form-bean> 元素中定义过。此项是可选项 |
path | 指定访问 Action 的路径,它以“ / ”开头,没有扩展名 |
parameter | 指定 Action 的配置参数。在 Action 类的 execute() 方法中,可以调用 ActionMapping 对象的 getParameter() 方法来读取该配置参数 |
roles | 指定允许调用该 Action 的安全角色。多个角色之间以逗号隔开。在处理请求时, RequestProcessor 会根据该配置项来决定用户是否有调用 Action 的权限 |
scope | 指定 ActionForm Bean 的存在范围,可选值为 request 和 session 。默认值为 session |
type | 指定 Action 类的完整类名 |
unknown | 如果此项为 true ,表示可以处理用户发出的所有无效的 Action URL 。默认值为 false |
validate | 指定是否要先调用 ActionForm Bean 的 validate() 方法。默认值为 true |
如果在 <action> 元素中定义了局部的 <forward> 元素,它的优先级别高于全局的 <forward> 元素。
例如:
<action-mappings >
<!-- input 验证失败时的转发路径 -->
<!-- path请求访问的Action的路径 -->
<!-- <forward>定义请求转发的路径 -->
<!-- path指明调用者(JSP)能通过中心控制器ActionServlet找到该Action -->
<action
path="/HelloWorld"
type="com.yourcompany.struts.action.HelloAction"
name="HelloForm"
scope="request"
validate="true"
input="/hello.jsp">
<forward name="SayHello" path="/hello.jsp" />
</action>
</action-mapping>
工作原理:
这段代码表明,如果用户的请求的URI为"HelloWord.do",那么Struts框架会把请求转发给Hello.Action;与HelloAction关联的表单为:HelloForm,它位于request范围。Struts框架会首先在配置文件中检索匹配的<form-bean>元素:
<form-beans >
<form-bean name="HelloForm" type="com.yourcompany.struts.form.HelloForm" />
</form-beans>
再把请求转发给HelloAction之前,先会调用HelloForm的validate()方法,如果表单验证失败则把请求转发给<action>元素的
input属性指定的hello.jsp文件。
对应的hello.jsp文件如下:
<html:form action="/HelloWorld.do" focus="userName">
<bean:message key="hello.jsp.promt.person"/>
<html:text property="userName" maxlength="16" size="16"></html:text>
<html:submit property="submit" value="Submit"></html:submit>
<html:reset></html:reset>
</html:form>
6、<controller> 元素
属性 | 描述 |
bufferSize | 指定上载文件的输入缓冲的大小。该属性为可选项,默认值为 4096 。 |
className | 指定和 <controller> 元素对应的配置类。默认值为 org.apache.struts.config.ControllerConfig 。 |
contentType | 指定响应结果的内容类型和字符编码。该属性为可选项,默认值为 text/html 。如果在 Action 和 JSP 网页中也设置了内容类型和字符编码,将会覆盖该设置 |
locale | 指定是否把 Locale 对象保存到当前用户的 Session 中。默认值为 false |
processorClass | 指定负责处理请求的 Java 类的完整类名。默认值为 org.apache.struts.action.RequestProcessor 。如果把此项设置为自定义的类,那么应该保持该类扩展了 org.apache.struts.action.RequestProcessor 类 |
tempDir | 指定处理文件上传的临时目录。如果此项没有设置,将采用 Servlet 容器为 Web 应用分配的临时工作目录 |
nochache | 如果为 true ,在响应结果中将加入特定的头参数: Pragma , Cache-Control 和 Expires ,防止页面被存储在客户浏览器的缓存中。默认值为 false |
如果应用包含多个子应用,可以在每个子应用的 Struts 配置文件中配置 <controller> 元素。这样,尽管这些子应用共享同一个 ActionServlet 对象,但是它们可以使用不同的 RequestProcessor 类。
<controller contentType="tex/html";charset="UTF-8"
locale="true"
processClass="CustomRequestProcessor"
/>
7、 <message-resources> 元素
属性 | 描述 |
className | 和 <message-resources> 元素对应的配置类。默认值为 org.apache.struts.config.MessageResourcesConfig |
factory | 指定消息资源的工厂类。默认值为 org.apache.struts.util.PropertyMessageResourcesFactory 类 |
key | 指定 Resource Bundle 存放在 ServletContext 对象中时采用的属性 key 。默认值为由 Globals.MESSAGES_KEY 定义的字符串常量。只允许有一个 Resource Bundle 采用默认的属性 key |
null | 指定 MessageResources 类如何处理未知的消息 key 。如果此项为 true ,将返回空字符串。如果此项为 false ,将返回类似“ ???global.label.missing??? ”的字符串。该属性为可选项,默认值为 true |
parameter | 指定 Resource Bundle 的消息资源文件名。 |
许多 Struts 客户化标签都通过 bundle 属性来指定 Resource Bundle ,标签的 bundle 属性和 <message-resources> 元素的 key 属性匹配。
如:<bean:message key="hello.jsp.page.hello"/>调用
<bean:message key="hello.jsp.page.hello" bundle="images">指定bundle
<message-resources parameter="com.yourcompany.struts.ApplicationResources1" />配置
<message-resources parameter="com.yourcompany.struts.ApplicationResources2" key="images" />配置
hello.jsp.page.hello=Hello com.yourcompany.struts.ApplicationResources1.2定义
10 <plug-in> 元素
<plug-in> 元素用于配置 Struts 插件。<plug-in> 元素的属性
属性 | 描述 |
className | 指定 Struts 插件类。插件类必需实现 org.apache.struts.action.PlugIn 接口 |
<plug-in className="org.apache.struts.validator.ValidatorPlugIn">
<set-property value="/WEB-INF/validator-rules.xml,/WEB-INF/validation.xml"/>
</plug-in>
11 配置多应用模块
(3) 采用 <forward> 元素或 SwitchAction 类来实现子应用之间的切换。
例如:
<init-param>
<param-name>config</param-name><!--参数名 -->
<param-value>/WEB-INF/struts-config.xml</param-value><!--文件名 -->
</init-param>
<init-param>
<param-name>config/application2</param-name>
<param-value>/WEB-INF/struts-module2.xml</param-value>
</init-param>
第二个<init-param>的名字必须以"config/"开头。子模块之间的切换有两种方式:
1、使用<forward>元素,全局或者局部的。但是它的contexRelative的属性应该设置为true.如:
<forward name="toModule2"
contexRelative="true"
path="/module2/index.do"
redirect="true"
>
</forward>
2.使用org.apcahe.struts.actions.SwitchAction类
<action-mapping>
<action path="/toModule"
type="org.apache.struts.actions.SwitchAction"
/>
</action-mapping>