`

struts.xml常用配置解析

阅读更多

使用<include>标签重用配置文件

在Struts2中提供了一个默认的struts.xml文件,但如果package、action、interceptors等配置比较多时,都 放到一个struts.xml文件不太容易维护。因此,就需要将struts.xml文件分成多个配置文件,然后在struts.xml文件中使用 <include>标签引用这些配置文件。这样做的优点如下:

结构更清晰,更容易维护配置信息。

配置文件可以复用。如果在多个Web程序中都使用类似或相同的配置文件,那么可以使用<include>标签来引用这些配置文件,这样可以减少工作量。

假设有一个配置文件,文件名为newstruts.xml,代码如下:

<?xmlversion="1.0"encoding="UTF-8"?>
<!DOCTYPEstrutsPUBLIC
"-//ApacheSoftwareFoundation//DTDStrutsConfiguration2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<packagename="demo"extends="struts-default">
<actionname="submit" class="action.MoreSubmitAction">
<resultname="save">
/result.jsp
</result>
<resultname="print">
/result.jsp
</result>
</action>
</package>
</struts>

则struts.xml引用newstruts.xml文件的代码如下:

<?xmlversion="1.0"encoding="UTF-8"?>
<!DOCTYPEstrutsPUBLIC
"-//ApacheSoftwareFoundation//DTDStrutsConfiguration2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<includefile="newstruts.xml"/>
<packagename="test"extends="struts-default">
……
</package>
</struts>

大家要注意一下,用<include>引用的xml文件也必须是完成的struts2的配置。实际上<include>在引用时是单独解析的xml文件,而不是将被引用的文件插入到struts.xml文件中。

action的别名

在默认情况下,Struts2会调用动作类的execute方法。但有些时候,我们需要在一个动作类中处理不同的动作。也就是用户请求不同的动作 时,执行动作类中的不同的方法。为了达到这个目的,可以在<action>标签中通过method方法指定要指行的动作类的方法名,并且需要为不同的动作 起不同的名子(也称为别名)。如下面代码所示:

<?xmlversion="1.0"encoding="UTF-8"?>
<!DOCTYPEstrutsPUBLIC
 "-//ApacheSoftwareFoundation//DTDStrutsConfiguration2.0//EN"
 "http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<packagename="demo"extends="struts-default">
<actionname="test" class="action.MyAction">
……
</action>
<actionname="my" class="action.MyAction"method="my">
……
</action>
</package>
</struts>

上面代码的两个动作的class属性都指向同一个类,name为这个类起了两个动作别名:test和my。在动作my中,使用了method属性指定要要运行的方法名为my。

在MyAction类中必须要有my方法,代码如下:

packageaction;
importcom.opensymphony.xwork2.ActionSupport;
publicclassMyActionextendsActionSupport
{
……
publicStringexecute()throwsException
{
//处理test动作的代码
}
publicStringmy()throwsException
{
 //处理my动作的代码
}
……
}

除了在struts.xml中配置别名,还可以通过请求参数来描述指定动作(并不需要在struts.xml中配置)。请求参数的格式如下:

http://localhost:8080/contextPath/actionName!method.action

 

为action指定参数

在struts2中还可以为action指定一个或多个参数。大家还记着struts1.x是如何设置的action参数不? 在struts1.x中可以使用<action>标签的parameter属性为其指定一个action参数,如果要指定多个,就只能通过逗号(,)或其 他的分隔符将不同的参数隔开。而在struts2中可以通过<param>标签指定任意多个参数。代码如下:

<actionname="submit" class="action.MyAction">
<paramname="param1">value1</param>
<paramname="param2">value2</param>
<resultname="save">
/result.jsp
</result>
 ……
</action>

当然,在action中读这些参数也非常简单,只需要象获取请求参数一样在action类中定义相应的setter方法即可(一般不用定义getter方法)。如下面的代码将读取param1和param2参数的值:

packageaction;
importcom.opensymphony.xwork2.ActionSupport;
publicclassMyActionextendsActionSupport
{
privateStringparam1;
privateStringparam2;
publicStringexecute()throwsException
{
System.out.println(param1+param2);
}
publicvoidsetParam1(Stringparam1)
{
this.param1=param1;
}
publicvoidsetParam2(Stringparam2)
{
this.param2=param2;
}
……
} 

当struts2在调用execute之前,param1和param2的值就已经是相应参数的值了,因此,在execute方法中可以直接使用param1和param2。

选择result类型

在默认时,标签的type属性值是“dispatcher”(实际上就是转发,forward)。开发人员可以根据自己的需要指定不同的类型,如redirect、stream等。如下面代码所示:

<result name="save"type="redirect">
  /result.jsp
</result>

这此result-type可以在struts2-core-2.0.11.1.jar包或struts2源代码中的struts- default.xml文件中找到,在这个文件中找到<result-types>标签,所有的result-type都在里面定义了。代码如下:

<result-types>
 <result-typename="chain"class="com.opensymphony.xwork2.ActionChainResult"/>
 <result-typename="dispatcher"class="org.apache.struts2.dispatcher.ServletDis
patcherResult"default="true"/>
 <result-typename="freemarker"class="org.apache.struts2.views.freemarker.Free
markerResult"/>
 <result-typename="httpheader"class="org.apache.struts2.dispatcher.HttpHeader
Result"/>
 <result-typename="redirect"class="org.apache.struts2.dispatcher.ServletRedir
ectResult"/>
 <result-typename="redirectAction"class="org.apache.struts2.dispatcher.Servle
tActionRedirectResult"/>
 <result-typename="stream"class="org.apache.struts2.dispatcher.StreamResult"/
>
 <result-typename="velocity"class="org.apache.struts2.dispatcher.VelocityResu
lt"/>
 <result-typename="xslt"class="org.apache.struts2.views.xslt.XSLTResult"/>
 <result-typename="plainText"class="org.apache.struts2.dispatcher.PlainTextRe
sult"/>
 <!--DeprecatednameformscheduledforremovalinStruts2.1.0.ThecamelCaseversionsa
repreferred.Seeww-1707-->
 <result-typename="redirect-action"class="org.apache.struts2.dispatcher.Servl
etActionRedirectResult"/>
 <result-typename="plaintext"class="org.apache.struts2.dispatcher.PlainTextRe
sult"/>
</result-types>

全局result

有很多时候一个<result>初很多<action>使用,这时可以使用<global-results>标签来定义全局的<result>,代码如下:

<struts>
<packagename="demo"extends="struts-default">
<global-results>
<resultname="print">/result.jsp</result>
</global-results>
<actionname="submit"class="action.MoreSubmitAction">
 ……
</action>
<actionname="my"class="action.MoreSubmitAction"method="my">
……
</action>
</package>
</struts>

如果<action>中没有相应的<result>,Struts2就会使用全局的<result>。

分享到:
评论

相关推荐

    struts2.0 教程(标签,XML配置,入门例子,帮助手册)

    "Struts2教程3:struts.xml常用配置解析 .doc"深入解析了struts.xml文件中的关键配置元素,包括常用于处理异常的global-exception-mappings,全局结果类型global-results,以及自定义拦截器栈。 "Struts2.0新标签的...

    struts2中两种validation.xml的配置方式

    其中,`validation.xml`是一种常用的配置文件,它支持定义字段级别的验证规则。这使得开发者可以在不修改Java代码的情况下调整验证逻辑,提高了开发效率。 ### 二、两种配置方式详解 #### 1. **Action级别的配置**...

    struts2的属性配置

    2. `web.xml`中的Struts2过滤器捕获请求,根据配置的`struts.action.extension`解析Action。 3. 过滤器调用Struts2的核心控制器,它负责解析Action配置,创建并执行相应的Action实例。 4. Action执行完业务逻辑后,...

    struts2学习教程

    struts2学习教程包括:第一个Struts2程序,处理一个form多个submit,struts.xml常用配置解析,使用validate方法验证数据,使用Validation框架验证数据,在Action类中获得HttpServletResponse对象的四种方法,上传...

    SSH和SSI等框架常用基础配置web.xml

    ### SSH和SSI等框架常用基础配置web.xml 在Java Web应用开发中,`web.xml`是部署描述符的核心部分,用于定义与Web应用程序相关的配置信息。对于使用SSH(Struts + Spring + Hibernate)和SSI(Struts + Spring + ...

    Web.xml的作用及常用标签的功能

    《深入理解Web.xml:作用与常用标签解析》 Web.xml文件是Java Web应用程序的核心配置文件,主要用于初始化工程的配置信息,包括但不限于欢迎页面、过滤器(filter)、监听器(listener)、Servlet、Servlet映射...

    struts2_strus.xml中result类型及含义详解

    本文将深入解析Struts2中的`result`类型及其含义,旨在帮助开发者更好地理解和应用这些配置,从而优化应用程序的表现和性能。 ### 1. Struts2中的Result概念 在Struts2中,当一个Action执行完毕后,它会根据Action...

    知识共享-struts1.2配置文件详解(雷惊风).

    标题与描述均指向了对Struts 1.2配置文件的深入解析,特别是web.xml与struts-config.xml这两个核心配置文件。以下是对这些关键知识点的详细解读: ### 一、Web配置文件web.xml #### 1. **Servlet与Servlet Mapping...

    Struts2.0框架技术详解

    #### 五、struts.xml常用配置解析 **5.1 使用标签重用配置文件** 通过`<include>`标签可以引入其他配置文件,实现配置文件的重用。 **示例**: ```xml <package name="default" extends="struts-default"> ...

    Struts2学习小结

    3. **解析请求**:Struts2 过滤器根据 `struts.xml` 配置文件查找匹配的命名空间 (`namespace`) 和动作 (`action`)。 4. **处理请求**:根据配置文件中指定的类执行相应的业务逻辑。 5. **返回结果**:执行完毕后,...

    struts的总结(struts1.x)

    要使用 Validator 插件,首先需要在 `struts-config.xml` 文件中进行配置,然后在 ActionForm 类中使用相应的注解或 XML 配置来进行验证。 #### 结语 本文对 Struts 1.x 的核心概念和技术进行了详细介绍,包括配置...

    struts+hibernate+Spring的整合

    - **Struts2**:Struts2的过滤器解析请求,根据struts.xml找到对应的Action。 - **Spring**:Struts2通过Spring的ObjectFactory获取Action实例,如果Action需要依赖其他服务,Spring会自动注入。 - **Hibernate**:...

    Struts2+Spring+Ibatis环境配置.doc

    2. `commons-lang.jar`:提供常用操作API,如字符串处理和XML解析。 3. `commons-logging.jar`:抽象的日志接口,允许开发者选择自己喜欢的日志实现。 4. `freemarker-2.3.8.jar`:用于生成动态HTML页面的模板引擎。...

    Struts2\constant应用

    #### 三、其他常用配置项解析 ##### 8. struts.enable.DynamicMethodInvocation **作用:** 设置Struts2是否支持动态方法调用,默认值为`true`。 **配置示例:** ```xml <constant name="struts.enable.Dynamic...

    struts2.0 hibernate3 spring2.5整合配置.doc

    #### 二、核心配置解析 **1. web.xml** `web.xml`是Web应用的核心配置文件,它包含了应用程序的初始化参数、过滤器、监听器等配置信息。 - **contextConfigLocation** 参数指定了Spring的配置文件位置,这里使用...

    struts-2.3.1.2常用包

    8. **配置文件**:主要的配置文件是`struts.xml`,在这里定义Action、拦截器栈和结果类型。2.3.1.2可能还包括其他相关的配置文件。 9. **依赖库**:压缩包中可能包含了一系列依赖库,如Apache Commons、OGNL...

    Struts2的配置文件DTD解析

    首先,Struts2的配置文件基于DTD来解析和验证其结构。DTD是一套规则,用于定义XML文档的合法结构和元素。在Struts2中,配置文件通常以`struts.xml`命名,它定义了不同的组件,如action、结果类型、拦截器等。 配置...

    Struts2配置时常用的包

    在Struts2的配置过程中,了解并掌握常用包的使用至关重要,这有助于提升开发效率并确保应用的稳定性和可扩展性。下面我们将深入探讨Struts2配置时涉及的一些关键包及其作用。 1. **struts2-core**:这是Struts2的...

    struts2学习笔记!

    在深入理解Struts2框架之前,我们首先需要了解其核心配置文件——`struts.xml`。 **1. struts.xml配置** ```xml <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation...

Global site tag (gtag.js) - Google Analytics