1、<struts-config> 元素
<struts-cofnig> 元素是 Struts 配置文件的根元素。<struts-config> 元素有 8 个子元素。在 Struts 配置文件中,必须按照它的 DTD 指定的先后顺序来配置 <struts-config> 元素的各个子元素,如果颠倒了这些子元素在配置文件中的顺序,在 Struts 应用启动时就会生成 XML 解析错误。
它的DTD定义如下:
|
1
2
3
|
<!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 类的完整类名(类的包名也包含在内),该属性是必需的 |
|
1
2
3
|
<form-beans > <form-bean name="HelloForm" type="com.yourcompany.struts.form.HelloForm" /></form-beans> |
| 属性 | 描述 |
| className | 指定和 <form-property> 元素对应的配置类,默认值为 org.apache.struts.config.FormPropertyConfig |
| initial | 以字符串的形式设置表单字段的初始值。如果没有设置该属性,则基本类型的表单字段的默认值为 0 ,对象类型的表单字段的默认值为 null |
| name | 指定表单字段的名字。该属性是必需的 |
| type | 指定表单字段的类型。如果表单资源为 Java 类,必须给出完整的类名。该属性是必需的。 |
|
1
2
3
4
5
6
7
8
|
<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 |
|
1
2
3
4
5
6
7
8
|
<strong><global-exception> <exception key="global.error.invalidlogin" path="/security/signin.jsp" scope="request" type="netstore.framework.exception.InvalidLoginException" /></global-exception> </strong> |
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 |
例如:
|
1
2
3
4
|
<global-forwards> <forward name="forward1" path="/Action1.do"></forward> <forward name="forward2" path="/JSP2.jsp"></forward></global-forwards><span style="font-family:SimSun;"> </span> |
如果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 、 include 和 type 属性相互排斥,也就是说只能设置其中的一项。 forward 属性的作用和 org.apache.struts.actions.ForwardAction 类相同。 Include 属性的作用和 org.apache.struts.actions.IncludeAction 类相同。
如果在 <action> 元素中定义了局部的 <forward> 元素,它的优先级别高于全局的 <forward> 元素。
例如:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
<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>元素:
|
1
2
3
|
<form-beans > <form-bean name="HelloForm" type="com.yourcompany.struts.form.HelloForm" /></form-beans> |
再把请求转发给HelloAction之前,先会调用HelloForm的validate()方法,如果表单验证失败则把请求转发给<action>元素的
input属性指定的hello.jsp文件。
对应的hello.jsp文件如下:
|
1
2
3
4
5
6
|
<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 类。
|
1
2
3
4
|
<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 接口 |
|
1
2
3
|
<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 类来实现子应用之间的切换。
例如:
|
1
2
3
4
5
6
7
8
|
<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.如:
|
1
2
3
4
5
6
|
<forward name="toModule2" contexRelative="true" path="/module2/index.do" redirect="true"></forward> |
2.使用org.apcahe.struts.actions.SwitchAction类
|
1
2
3
4
5
|
<action-mapping> <action path="/toModule" type="org.apache.struts.actions.SwitchAction" /></action-mapping> |