`

struts2配置-struts.xml

阅读更多
struts.xml配置文件
 
        Struts框架的核心配置文件就是struts.xml配置文件,该文件主要负责管理Struts 2框架的业务控制器Action。
 
        在默认情况下,Struts 2框架将自动加载放在WEB-INF/classes路径下的struts.xml文件。在大部分应用里,随着应用规模的增加,系统中Action数量也大量增加,导致struts.xml配置文件变得非常臃肿。
 
         为了避免struts.xml文件过于庞大、臃肿,提高struts.xml文件的可读性,我们可以将一个struts.xml配置文件分解成多个配置文件,然后在struts.xml文件中包含其他配置文件。
 
        下面的struts.xml文件中就通过include手动导入了一个配置文件:struts-part1.xml文件,通过这种方式,就可以将Struts 2的Action按模块配置在多个配置文件中。
   ----------------------------------------------------------------------------------------------------------------------------
   <?xml version="1.0" encoding="UTF-8" ?>
   <!-- 指定Struts 2配置文件的DTD信息 -->
   <!DOCTYPE struts PUBLIC
        "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
        "http://struts.apache.org/dtds/struts-2.0.dtd">
   <!-- 下面是Struts 2配置文件的根元素 -->
   <struts>
           <!-- 通过include元素导入其他配置文件 -->
           <include file="struts-part1.xml" />
             ...
   </struts>
   ----------------------------------------------------------------------------------------------------------------------------
   
   通过这种方式,Struts 2提供了一种模块化的方式来管理struts.xml配置文件。
 
   除此之外,Struts 2还提供了一种插件式的方式来管理配置文件。用WinRAR等解压缩软件打开struts2-core-2.0.6.jar文件,看到如图3.21所示的文件结构,在光标选中的一行,看到有一个struts-default.xml文件。

   
   
   图3.21  struts2-core-2.0.6.jar压缩文件的文件结构
 
   查看struts-default.xml文件,看到该文件代码片段如下:
   --------------------------------------------------------------------------------------
   <?xml version="1.0" encoding="UTF-8" ?>
   <!-- 指定Struts 2配置文件的DTD信息 -->
   <!DOCTYPE struts PUBLIC
            "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
   <!-- Struts 2配置文件的根元素 -->
   <struts>
             <!-- 下面定义了Struts 2框架的一些基础Bean  -->
               <bean class="com.opensymphony.xwork2.ObjectFactory" name="xwork" />
               <bean type="com.opensymphony.xwork2.ObjectFactory" name="struts"
                      class="org.apache.struts2.impl.StrutsObjectFactory" />
                       ....
                <!-- 下面是一些静态注入Bean定义 -->
                <bean class="com.opensymphony.xwork2.util.OgnlValueStack" static="true" />
                <bean class="org.apache.struts2.dispatcher.Dispatcher" static="true" />
                ...
                <!-- 下面定义Struts 2的默认包空间 -->
                <package name="struts-default">
                <!-- 定义Struts 2内建支持的结果类型 -->
                   <result-types>
                         <!-- 定义Action链Result类型 -->
                         <result-type name="chain" class="com.opensymphony.xwork2. ActionChainResult"/>
                         <!-- 定义Dispatcher的Result类型,并设置default="true",指定该结果Result是默认的Result类型 -->
                         <result-type name="dispatcher"  class="org.apache.struts2.dispatcher.Servlet DispatcherResult" default="true"/>
                         <!-- 定义FreeMarker的Result类型 -->
                         <result-type name="freemarker"class="org.apache.struts2.views.freemarker. FreemarkerResult"/>
                         ...
                    </result-types>
                    <!-- 定义Struts 2内建的拦截器 -->
                    <interceptors>
                    <interceptor name="alias" class="com.opensymphony.xwork2. interceptor.AliasInterceptor"/>
                    <interceptor name="autowiring" class="com.opensymphony.xwork2.spring.interceptor. ActionAutowiringInterceptor"/>
                     ...
                     <!-- 定义基本拦截器栈 -->
                                   <interceptor-stack name="basicStack">
                                   <interceptor-ref name="exception"/>
                                   <interceptor-ref name="servlet-config"/>
                                   <interceptor-ref name="prepare"/>
                                   <interceptor-ref name="checkbox"/>
                                   <interceptor-ref name="params"/>
                                   <interceptor-ref name="conversionError"/>
                                   </interceptor-stack>
                                        <!-- 还有系列拦截器栈 -->
                                        ... 
                                  </interceptors>
                   <!-- 定义默认的拦截器栈引用 -->
                  <default-interceptor-ref name="defaultStack"/>
                  </package>
    </struts>
    --------------------------------------------------------------------------------------
   上面的代码并未全部列出struts-default.xml文件,只是列出了每个元素的代表。上面配置文件中定义了一个名字为struts-default的包空间,该包空间里定义了Struts 2内建的Result类型,还定义了Struts 2内建的系列拦截器,以及由不同拦截器组成的拦截器栈,文件的最后还定义了默认的拦截器引用。
 
   这个struts-default.xml文件是Struts 2框架的默认配置文件,Struts 2框架每次都会自动加载该文件。查看我们前面使用的struts.xml文件,看到我们自己定义的package元素有如下代码片段:
   
   --------------------------------------------------------------------------------------
   <!-- 指定Struts 2配置文件的根元素 -->
   <struts>
            <!-- 配置名为lee的包空间,继承struts-default包空间 -->
            <package name="lee" extends="struts-default">
                                    ...
            </package>
   </struts>
   --------------------------------------------------------------------------------------
   
   在上面配置文件中,名为lee的包空间,继承了名为struts-default的包空间,struts-default包空间定义在struts-default.xml文件中。可见,Struts 2框架默认会加载struts-default.xml文件。
 
   不仅如此,Struts 2框架提供了一种类似Eclipse的扩展方式,它允许以一种“可插拔”的方式来安装插件,例如后面将要介绍的Spring插件、JSF插件等,它们都提供了一个类似struts2-Xxx-plugin.jar的文件——这个文件就是插件安装文件,只要将该文件放在Web应用的WEB-INF/lib路径下,Struts 2框架将自动加载该框架。
 
   使用WinRAR工具打开struts2-spring-plugin2.06.jar文件,找到一个struts-plugin.xml文件,打开该文件,该文件的代码如下:
   --------------------------------------------------------------------------------------
   <?xml version="1.0" encoding="UTF-8" ?>
   <!-- 指定Struts 2的DTD信息 -->
   <!DOCTYPE struts PUBLIC
       "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
   <struts>
           <!-- 定义一个名字为spring的ObjectFactory -->
           <bean type="com.opensymphony.xwork2.ObjectFactory" name="spring" class="org.apache.struts2.spring.StrutsSpringObjectFactory" />
           <!-- 指定名字为sping的ObjectFactory是Struts 2的ObjectFactory -->
           <constant name="struts.objectFactory" value="spring" />
           <!-- 定义名为spring-default的包空间 -->
           <package name="spring-default">
                  <!-- 定义整合Spring框架所必需的拦截器列表 -->
                  <interceptors>
                             <interceptor name="autowiring" class="com.opensymphony.xwork2.spring.interceptor. ActionAutowiringInterceptor"/>
                             <interceptor name="sessionAutowiring" class="org.apache.struts2.spring.interceptor. SessionContextAutowiringInterceptor"/>
                  </interceptors>
           </package>
    </struts>
    在上面配置文件中,配置了Struts 2与Spring框架整合必需的常量、拦截器等——这也是Struts 2框架使用Spring插件必需的配置。只要将struts2-spring-plugin2.06.jar文件放在WEB-INF/lib路径下,Struts 2框架将自动加载该文件。
 
 struts.xml文件结构
 
struts.xml文件是整个Struts 2框架的核心,下面提供了一个最完整的struts.xml文件,这个文件没有任何实际意义,仅仅是一个struts.xml文件示范。
    ---------------------------------------------------------------------------------------------------------------------------
    <?xml version="1.0" encoding="GBK"?>
    <!-- 下面指定Struts 2配置文件的DTD信息 -->
    <!DOCTYPE struts PUBLIC
        "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
    <!-- struts是Struts 2配置文件的根元素 -->
    <struts>
              <!-- 下面元素可以出现0次,也可以无限多次 -->
              <constant name="" value="" />
              <!-- 下面元素可以出现0次,也可以无限多次 -->
              <bean type="" name="" class="" scope="" static="" optional="" />
              <!-- 下面元素可以出现0次,也可以无限多次 -->
              <include file="" />
              <!-- package元素是Struts配置文件的核心,该元素可以出现0次,或者无限多次 -->
              <package name="必填的包名" extends="" namespace="" abstract="" externalReferenceResolver>
                       <!-- 该元素可以出现,也可以不出现,最多出现一次 -->
                       <result-types>
                                     <!-- 该元素必须出现,可以出现无限多次-->
                                     <result-type name="" class="" default="true|false">
                                     <!-- 下面元素可以出现0次,也可以无限多次 -->
                                            <param name="参数名">参数值</param>*
                                     </result-type>
                       </result-types>
                       <!-- 该元素可以出现,也可以不出现,最多出现一次 -->
                       <interceptors>
                                     <!-- 该元素的interceptor元素和interceptor-stack至少出现其中之一,也可以二者都出现 -->
                                     <!-- 下面元素可以出现0次,也可以无限多次 -->
                                     <interceptor name="" class="">
                                            <!-- 下面元素可以出现0次,也可以无限多次 -->
                                            <param name="参数名">参数值</param>*
                                     </interceptor>
                                     <!-- 下面元素可以出现0次,也可以无限多次 -->
                                     <interceptor-stack name="">
                                            <!-- 该元素必须出现,可以出现无限多次-->
                                            <interceptor-ref name="">
                                                <!-- 下面元素可以出现0次,也可以无限多次 -->
                                                <param name="参数名">参数值</param>*
                                            </interceptor-ref>
                                     </interceptor-stack>
                     </interceptors>
                     <!-- 下面元素可以出现0次,也可以无限多次 -->
                     <default-interceptor-ref name="">
                            <!-- 下面元素可以出现0次,也可以无限多次 -->
                            <param name="参数名">参数值</param>
                      </default-interceptor-ref>
                      <!-- 下面元素可以出现0次,也可以无限多次 -->
                      <default-action-ref name="">
                             <!-- 下面元素可以出现0次,也可以无限多次 -->
                              <param name="参数名">参数值</param>*
                        </default-action-ref>?
                        <!-- 下面元素可以出现0次,也可以无限多次 -->
                         <global-results>
                               <!-- 该元素必须出现,可以出现无限多次-->
                               <result name="" type="">
                                <!-- 该字符串内容可以出现0次或多次 -->
                                            映射资源
                                <!-- 下面元素可以出现0次,也可以无限多次 -->
                                      <param name="参数名">参数值</param>*
                                </result>
                          </global-results>
                          <!-- 下面元素可以出现0次,也可以无限多次 -->
                           <global-exception-mappings>
                                 <!-- 该元素必须出现,可以出现无限多次-->
                                 <exception-mapping name="" exception="" result="">
                                            异常处理资源
                                            <!-- 下面元素可以出现0次,也可以无限多次 -->
                                            <param name="参数名">参数值</param>*
                                 </exception-mapping>
                           </global-exception-mappings>
                           <action name="" class="" method="" converter="">
                                        <!-- 下面元素可以出现0次,也可以无限多次 -->
                                        <param name="参数名">参数值</param>*
                                        <!-- 下面元素可以出现0次,也可以无限多次 -->
                                        <result name="" type="">
                                            映射资源
                                            <!-- 下面元素可以出现0次,也可以无限多次 -->
                                            <param name="参数名">参数值</param>*
                                        </result>
                                        <!-- 下面元素可以出现0次,也可以无限多次 -->
                                        <interceptor-ref name="">
                                            <!-- 下面元素可以出现0次,也可以无限多次 -->
                                            <param name="参数名">参数值</param>*
                                        </interceptor-ref>
                                        <!-- 下面元素可以出现0次,也可以无限多次 -->
                                        <exception-mapping name="" exception="" result="">
                                            异常处理资源
                                            <!-- 下面元素可以出现0次,也可以无限多次 -->
                                            <param name="参数名">参数值</param>*
                                        </exception-mapping>
                          </action>
             </package>*
    <struts>
    ---------------------------------------------------------------------------------------------------------------------------
    
    
    上面的struts.xml配置文件是一个非常全面的配置文件,包含了Struts 2的全部配置元素。上面配置文件主要用于帮助对XML DTD不太熟悉的读者。
 
    通过上面给出的struts.xml配置文件范例,我们已经可以全面掌握Struts 2配置文件的文件结构了,但struts.xml文件各配置元素的意义、各属性的相关含义依然不能深入了解。
分享到:
评论
3 楼 king130520 2010-07-30  
2 楼 fenglingyesiyu 2010-07-26  
如果再加上配置元素的意义、各属性的相关含义就更好了
1 楼 fenglingyesiyu 2010-07-26  
那么详细,非常有用

相关推荐

    struts-config.xml struts标准配置文件 struts-config

    struts-config.xml struts标准配置文件 struts-config

    Struts框架中struts-config.xml文件配置小结

    ### Struts框架中struts-config.xml文件配置详解 #### 一、引言 在Java Web开发领域,Struts是一个非常重要的MVC(Model-View-Controller)框架,它极大地简化了Web应用程序的开发过程。而在Struts框架中,`struts...

    struts2-core-2.0.12.jar

    Struts2的配置主要在struts.xml文件中进行,这里定义了Action的映射、结果类型、拦截器栈等。开发者可以通过XML或注解方式来配置Action,使应用更加灵活。 **4. 拦截器(Interceptors)** 拦截器是Struts2的一大...

    struts2-json-plugin-2.3.8.jar

    在实际开发中,为了使用这个插件,你需要将`struts2-json-plugin-2.3.8.jar`文件放入项目的类路径(classpath)下,然后在Struts2的配置文件(通常为struts.xml)中启用JSON插件。在Action类中,定义返回JSON数据的...

    struts2-core-2.2.1-sources.jar

    struts2-core-2.2.1-sources.jar 源码,学strut2源码时能用到的

    struts-2.3.31-all.zip

    5. **注解支持**:Struts2支持使用注解进行配置,减少了XML配置文件的使用,提高了开发效率。 6. **Freemarker和JSP视图技术**:Struts2可以与Freemarker或JSP一起工作,用于渲染视图。Freemarker是一种模板语言,...

    Struts2最新漏洞升级2.3.32版本

    3、修改 WEB-INF\classes 目录下struts.xml 文件,加上: &lt;constant name="struts.enable.DynamicMethodInvocation" value="true"/&gt; &lt;constant name="struts.convention.action.mapallmatches" value="true"/&gt; 这...

    SSH\\others\\struts2-spring-plugin-2.2.1.jar

    在使用Struts2 Spring Plugin时,开发者需要在Struts配置文件(struts.xml)中添加必要的配置,声明插件并指定Spring应用上下文的位置。这样,当Struts2框架处理请求时,它会查找并使用Spring容器中的Action实例。 ...

    struts-1.3.8-all.zip

    使用Struts 1.3.8时,开发者需要配置web.xml和struts-config.xml,定义ActionServlet、Action、ActionForm等元素。此外,还需要编写ActionForm类,实现业务逻辑的Action类,以及使用JSP和Struts标签创建用户界面。 ...

    struts-2.5.20-all.rar

    2. **配置文件**:Struts2使用XML配置文件(通常命名为struts.xml或struts-default.xml)来定义Action、结果、拦截器等。这些配置告诉Struts如何映射HTTP请求到Action类,以及Action执行后如何显示结果。 3. **拦截...

    配置struts--config.xml详解

    在 Struts 应用程序中,`struts-config.xml` 文件是核心配置文件,它定义了应用的行为、控制器(Actions)、数据源(Form Beans)以及视图(JSP 页面)之间的关系。本文将深入探讨 `struts-config.xml` 的主要元素和...

    struts2-spring-plugin-2.2.1.jar

    5. **简化配置**:通过插件,开发者不再需要在struts.xml或web.xml中显式配置Action的类名和实例,只需在Spring配置文件中定义Bean即可。 6. **提高代码可测试性**:由于Action由Spring管理,可以更容易地进行单元...

    struts2-core-2.1.6.jar

    7. **配置文件**:Struts2的配置通常分为XML配置和注解配置两种方式。struts.xml文件用于定义Action、Result、Interceptor等,而注解配置可以直接在Action类上声明,简化配置过程。 8. **异常处理**:Struts2提供了...

    struts-2.3.37-all.zip

    6. **配置文件**:Struts 2的配置分为XML配置和注解配置两种方式。`struts.xml`是主要的配置文件,用于定义Action、结果、拦截器栈等。 7. **插件架构**:Struts 2支持插件机制,允许开发者轻松地添加新的功能或...

    struts-2.5.2-all.zip

    2. **配置文件**:主要包括`struts.xml`,这是Struts 2的主配置文件,用于定义Action、结果类型、拦截器等。通过配置文件,开发者可以灵活地控制请求的映射和处理方式。 3. **拦截器(Interceptors)**:这是Struts...

    struts-config.xml

    `struts-config.xml`是Struts框架的核心配置文件,它定义了应用的各个组件及其交互方式。下面将详细介绍这个配置文件的主要元素和子元素。 ### 主要元素 1. **`&lt;data-sources&gt;`**: 这个元素用于配置数据源,通常...

    struts2-core-2.1.8.1 xwork-core-2.1.6源码

    4. **配置管理(Configuration Manager)**:Struts2的配置管理器负责读取配置文件(如struts.xml),并将配置信息加载到内存中。这部分代码主要位于`com.opensymphony.xwork2.config`包下,包括`Configuration`接口...

    struts2-spring-plugin-2.5.13.jar

    搭建struts2 + spring框架时需要使用的关联jar struts.xml中action的属性class引用applicationContext中bean的属性id指向的值

    struts2-convention-plugin-2.1.8.1.jar

    struts2-convention-plugin-2.1.8.1.jar

    struts-2.3.15.1-lib.zip官方jar包

    4. **配置更新**:根据官方文档更新配置文件,如struts.xml或web.xml,以适应新版本的要求。 5. **测试**:升级后,进行详尽的功能测试和安全性测试,确保所有功能正常且没有新的安全漏洞引入。 6. **监控**:升级...

Global site tag (gtag.js) - Google Analytics