zoukankan      html  css  js  c++  java
  • 深入Struts2的配置文件

    本篇的主要内容是讲解struts.xml文件中每个元素的含义.

    1)  Bean配置
    Struts2框架是一个高度可扩展的框架,框架的大部分核心组件,Struts2并不是直接以硬编码的方式写在代码中的,而是以自己的IOC(控制反转容器)来管理框架的核心组件.

    Struts2框架以可配置的方式来管理Struts2的核心组件,从而允许开发者可以非常方便的扩展该框架的核心组件.当开发者需要扩展,或者替换Struts2的核心组件的时候,只需要提供自己的组件实现类,并且将组件实现类部署在Struts2的IOC容器当中就可以了.

    打开Struts-core-2.1.6.jar压缩文件中的struts-default.xml文件,看到在该文件中配置了大量的Bean定义,该配置文件的代码如下:

    view plaincopy to clipboardprint?
    01.<!—下面配置了Struts2的三个类型检测器Bean --> 
    02. 
    03.<bean type="com.opensymphony.xwork2.conversion.ObjectTypeDeterminer" name="tiger" class="com.opensymphony.xwork2.conversion.impl.DefaultObjectTypeDeterminer"/> 
    04. 
    05.<bean type="com.opensymphony.xwork2.conversion.ObjectTypeDeterminer" name="notiger" class="com.opensymphony.xwork2.conversion.impl.DefaultObjectTypeDeterminer"/> 
    06. 
    07.<bean type="com.opensymphony.xwork2.conversion.ObjectTypeDeterminer" name="struts" class="com.opensymphony.xwork2.conversion.impl.DefaultObjectTypeDeterminer"/> 
    08. 
    09.<!—下面配置了Struts2的两个文件上传器Bean --> 
    10. 
    11.<bean type="org.apache.struts2.dispatcher.multipart.MultiPartRequest" name="struts" class="org.apache.struts2.dispatcher.multipart.JakartaMultiPartRequest" scope="default"/> 
    12. 
    13.<bean type="org.apache.struts2.dispatcher.multipart.MultiPartRequest" name="jakarta" class="org.apache.struts2.dispatcher.multipart.JakartaMultiPartRequest" scope="default" /> 
    14. 
    15.<!—下面配置了Struts2的标签库处理的Bean --> 
    16. 
    17.<bean type="org.apache.struts2.views.TagLibrary" name="s" class="org.apache.struts2.views.DefaultTagLibrary" /> 
    <!—下面配置了Struts2的三个类型检测器Bean -->

    <bean type="com.opensymphony.xwork2.conversion.ObjectTypeDeterminer" name="tiger" class="com.opensymphony.xwork2.conversion.impl.DefaultObjectTypeDeterminer"/>

    <bean type="com.opensymphony.xwork2.conversion.ObjectTypeDeterminer" name="notiger" class="com.opensymphony.xwork2.conversion.impl.DefaultObjectTypeDeterminer"/>

    <bean type="com.opensymphony.xwork2.conversion.ObjectTypeDeterminer" name="struts" class="com.opensymphony.xwork2.conversion.impl.DefaultObjectTypeDeterminer"/>

    <!—下面配置了Struts2的两个文件上传器Bean -->

    <bean type="org.apache.struts2.dispatcher.multipart.MultiPartRequest" name="struts" class="org.apache.struts2.dispatcher.multipart.JakartaMultiPartRequest" scope="default"/>

    <bean type="org.apache.struts2.dispatcher.multipart.MultiPartRequest" name="jakarta" class="org.apache.struts2.dispatcher.multipart.JakartaMultiPartRequest" scope="default" />

    <!—下面配置了Struts2的标签库处理的Bean -->

    <bean type="org.apache.struts2.views.TagLibrary" name="s" class="org.apache.struts2.views.DefaultTagLibrary" />

    上面的配置文件配置了Struts2框架的内置Bean,其中有三个类型检测Bean,就是在前面struts.properties文件中允许使用的类型检测器.( struts.objectTypeDeterminer:该属性指定Struts2的类型检测机制,通常支持tiger和notiger两个属性值.).

    在struts.xml文件中定义Bean的时候,通常有如下两个作用:

    l         创建该Bean的实例,将该实例作为Struts2框架的核心组件使用.

    l         Bean包含的静态方法需要一个值的注入

    在第一种用法下,因为Bean实例往往是作为一个核心组件使用的,因此需要告诉Struts2容器该实例的作用----就是该实例实现了哪个接口,这个接口往往定义了该组件所必须遵守的一个规范.

    比如说下面的配置片段,我们使用了一个自定义的ObjectFactory来替代了Struts2内置的ObjectFactory.替换ObjectFactory的代码片段如下:

    view plaincopy to clipboardprint?
    01.<?xml version="1.0" encoding="UTF-8"?> 
    02. 
    03. <!DOCTYPE struts PUBLIC  
    04. 
    05.    "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN"  
    06. 
    07.    "http://struts.apache.org/dtds/struts-2.1.dtd"> 
    08. 
    09.    <struts> 
    10. 
    11.        <!-- 配置定制的ObjectFactory Bean,该Bean实现了  
    12. 
    13.             ObjectFactory接口,实现类是MyObjectFactory --> 
    14. 
    15.        <bean type="com.opensymphony.xwork2.ObjectFactory" 
    16. 
    17.             name="myfactory" class="com.supermos.app.MyObjectFactory"/> 
    18. 
    19.    </struts> 
    <?xml version="1.0" encoding="UTF-8"?>

     <!DOCTYPE struts PUBLIC

        "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN"

        "http://struts.apache.org/dtds/struts-2.1.dtd">

        <struts>

            <!-- 配置定制的ObjectFactory Bean,该Bean实现了

                 ObjectFactory接口,实现类是MyObjectFactory -->

            <bean type="com.opensymphony.xwork2.ObjectFactory"

                 name="myfactory" class="com.supermos.app.MyObjectFactory"/>

        </struts>
     


     

    对于第二种用法,可以很方便的不创建某个类的实例,却可以接受框架的常量,在这种方式下,通常要设置static=”true”.

    下面是struts-default.xml配置文件的代码片段:

    view plaincopy to clipboardprint?
    01.<struts> 
    02. 
    03.    <bean class=”org.apache.struts.dispatcher.FilterDispatcher” static=”true”/> 
    04. 
    05.</struts> 
    <struts>

        <bean class=”org.apache.struts.dispatcher.FilterDispatcher” static=”true”/>

    </struts>
     

    (?为什么这个地方我没有在struts-default.xml(2.1.6版)中没有找到?莫非是被删除咧?)

    对于大部分Struts2应用而言,我们不需要重新定义Struts2框架的核心组件,也就不需要在struts.xml文件中定义Bean.

    正如前面看到的,使用<bean/>元素在struts.xml文件中定义Bean,Bean元素有如下几个属性:

    l         class:这个属性石必填属性,他指定了Bean实例的实现类

    l         type:这个属性是可选属性,它指定了Bean实例实现的Struts2的规范,该规范通常是通过某个接口来实现的,因此该属性的值通常就是一个Struts接口.如果需要将Bean实例作为Struts2的组件来使用的话,则应该制定该属性值.

    l         name:该属性指定了Bean实例的名字,对于有相同type类型的多个Bean则他们的name属性不能够相同,这个属性也是一个可选属性.

    l         scope:该属性指定Bean实例的作用域,该属性是一个可选的属性,属性值只能是default.singlton,request,session或者thread其中的一个.

    l         static:该属性指定Bean是否使用静态方法注入.通常而言,当指定了type属性的时候,该属性不应该指定为true.

    l         optional:该属性指定该Bean是否是一个可选的Bean,该属性是一个可选的属性.

    2)  常量配置
    在struts.xml文件中配置常量是一种指定Struts2属性的方式.配置Struts2属性有两种方式,一种是在struts.xml中配置,一种是在struts.properties中进行属性的配置.实际上,这两种方式的作用是基本相似的.

    (通常都是在struts.xml文件当中来对Struts2进行属性的配置,一般不需要在struts.properties文件中定义Struts2属性,之所以要保留使用struts.properties文件定义Struts2属性的方式,主要是为了保持与WebWork的向后的兼容性)

    这样看起来,Struts2的常量既可以在struts.xml文件中配置,也可以再struts.properties文件中配置.实际上,还可以在web.xml文件中配置Struts2常量.

    通常,Struts2框架按照如下搜索顺序加载Struts2常量:

    l         struts-default.xml该文件保存在struts2-core-2.x..x.jar文件当中.

    l         struts-plugin.xml该文件保存在struts2-Xxx-2.x.x.jar等Struts2插件JAR文件当中
    l         struts.xml该文件是WEB应用默认的Struts2配置文件
    l         struts.properties该文件是web应用默认的Struts2配置文件
    l         web.xml该文件时web应用的配置文件
    上面指定了Struts2框架搜索Struts2常量的顺序,如果在多个文件当中配置了同一个Struts2常量,则后一个文件中配置的常量就会覆盖前面文件中配置的常量.

    在不同的文件中,配置常量的方式是不一样的,但是不管在哪个文件当中,配置Struts2常量都需要制定两个属性,常量name和常量value.

    其中在Struts.xml文件中通过constant元素来配置常量,配置常量需要指定两个必填的属性:

    ①     name:该属性指定了常量name

    ②     value:该属性指定了常量value

    例如,如果需要指定Struts2国际化资源文件的baseName为mess,那么就可以在Struts.xml文件中通过如下代码来进行配置:

    view plaincopy to clipboardprint?
    01.<?xml version="1.0" encoding="UTF-8"?> 
    02. 
    03.<!DOCTYPE struts PUBLIC  
    04. 
    05.  "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN"  
    06. 
    07.  "http://struts.apache.org/dtds/struts-2.1.dtd"> 
    08. 
    09.  <struts> 
    10. 
    11.      <constant name="struts.custom.i18n.resources" value="mess"/> 
    12. 
    13.</struts> 
    <?xml version="1.0" encoding="UTF-8"?>

    <!DOCTYPE struts PUBLIC

      "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN"

      "http://struts.apache.org/dtds/struts-2.1.dtd">

      <struts>

          <constant name="struts.custom.i18n.resources" value="mess"/>

    </struts>
     


     

    对于struts.properties文件而言,该文件的内容就是系列的key-value对,其中每个key对应一个Struts2的常量的name,每个value对应一个Struts2常量value.

    比如说如下的代码段:

    #指定了Struts2应用处于开发阶段

    struts.devMode=true

    上面的配置片段配置了名字为struts.devMode的Struts2常量,该常量值为true

    在web.xml文件中配置Struts2常量,可以通过<filter>元素的<init-param>元素来指定,每个<init-param>元素配置了一个Struts2常量.

    下面的代码在web.xml文件中,配置了Struts2应用所需要的国际化资源文件的baseName:

    view plaincopy to clipboardprint?
    01.<?xml version="1.0" encoding="UTF-8"?> 
    02. 
    03.<web-app version="2.4"   
    04. 
    05.    xmlns="http://java.sun.com/xml/ns/j2ee"   
    06. 
    07.    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   
    08. 
    09.    xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee   
    10. 
    11.    http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"> 
    12. 
    13.    <filter> 
    14. 
    15.        <filter-name>Struts2</filter-name> 
    16. 
    17.        <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class> 
    18. 
    19.        <init-param> 
    20. 
    21.            <param-name>mess</param-name> 
    22. 
    23.            <param-value>struts.custom.i18n.resources</param-value> 
    24. 
    25.        </init-param> 
    26. 
    27.    </filter> 
    28. 
    29.    <filter-mapping> 
    30. 
    31.        <filter-name>Struts2</filter-name> 
    32. 
    33.        <url-pattern>/*</url-pattern> 
    34. 
    35.    </filter-mapping> 
    36. 
    37.    <welcome-file-list> 
    38. 
    39.        <welcome-file>login.jsp</welcome-file> 
    40. 
    41.    </welcome-file-list> 
    42. 
    43.</web-app> 
    <?xml version="1.0" encoding="UTF-8"?>

    <web-app version="2.4"

        xmlns="http://java.sun.com/xml/ns/j2ee"

        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

        xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee

        http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">

        <filter>

            <filter-name>Struts2</filter-name>

            <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>

            <init-param>

                <param-name>mess</param-name>

                <param-value>struts.custom.i18n.resources</param-value>

            </init-param>

        </filter>

        <filter-mapping>

            <filter-name>Struts2</filter-name>

            <url-pattern>/*</url-pattern>

        </filter-mapping>

        <welcome-file-list>

            <welcome-file>login.jsp</welcome-file>

        </welcome-file-list>

    </web-app>
     


     

    在上面的web.xml文件当中,当配置FilterDispatcher的时候,还通过init-param子元素来配置了Struts2常量,指定了国际化资源文件的baseName为mess.

    在实际开发中,Struts2的常量通常不配置在web.xml当中,如果采用这种配置在web.xml的形式,需要更多的代码,而且降低了web.xml文件的可读性,通常推荐将Struts2常量集中在struts.xml文件中进行集中的管理.

    3)  包配置
    Struts2框架中,核心组件就是Action,拦截器等等,Struts2框架使用包来管理Action和拦截器等等,每个包就是多个Action,多个拦截器,多个拦截器应用的集合

    配置包的时候,必须要指定name属性,这个属性是引用这个包的key.除此之外,还可以指定一个可选的extends属性,extends属性值必须是另外一个包的属性.指定extends属性表示让该表继承其他包,子包可以继承一个或者多个父包中的拦截器,拦截器栈,action等配置.

    除此之外,Struts2还提供了一种所谓的抽象包,抽象包的含义是该包不能包含Action定义.为了显示的指定一个包是抽象包,可以为该package元素增加abstract=”true”属性.

    在struts.xml当中,package用于定义包配置,每个package元素定义了一个包配置,在定义package元素的时候可以指定如下几个属性:

    l         name:这是一个必填的属性,该属性指定了该包的名字,该名字是该包被其他包引用的key.

    l         extends:该属性是一个可选的属性,该属性指定该包继承其他的包.可以继承其他包中的Action定义,拦截器定义等等.

    l         namespace:该属性是一个可选的属性,该属性定义该包的命名空间.

    l         abstract:该属性是一个可选的属性,它指定该包是否是一个抽象包,抽象包不能包含Action定义.(因为Struts2的配置文件是从上到下处理的,所以父包应该放在子包前面来定义.)

    下面是一个简单的struts.xml配置文件的范例,在下面的struts.xml文件当中配置了两个包,其中名为default的包,继承了Struts2框架的默认包struts-default.

    view plaincopy to clipboardprint?
    01.<?xml version="1.0" encoding="UTF-8"?> 
    02. 
    03.<!DOCTYPE struts PUBLIC  
    04. 
    05.  "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN"  
    06. 
    07.  "http://struts.apache.org/dtds/struts-2.1.dtd"> 
    08. 
    09.  <struts> 
    10. 
    11.      <!-- 配置第一个包,该包的名字为default继承自struts-default --> 
    12. 
    13.      <package name="default" extends="struts-default"> 
    14. 
    15.          <!-- 下面定义了拦截器部分 --> 
    16. 
    17.          <interceptors> 
    18. 
    19.              <!-- 定义拦截器栈 --> 
    20. 
    21.              <interceptor-stack name="crudStack"> 
    22. 
    23.                  <interceptor-ref name="params"/> 
    24. 
    25.                  <interceptor-ref name="defaultStack"/> 
    26. 
    27.              </interceptor-stack> 
    28. 
    29.          </interceptors> 
    30. 
    31.          <default-action-ref name="showcase"/> 
    32. 
    33.          <!-- 定义一个Action,该Action直接映射到showcase.jsp页面 --> 
    34. 
    35.          <action name="Showcase"> 
    36. 
    37.              <result>showcase.jsp</result> 
    38. 
    39.          </action> 
    40. 
    41.          <!-- 定义了一个Action,该Action类为com.opensymphony.webwork.showcase.DateAction --> 
    42. 
    43.          <action name="Date" class="supermos.DateAction"> 
    44. 
    45.              <result name="success">/date.jsp</result> 
    46. 
    47.          </action> 
    48. 
    49.      </package> 
    50. 
    51.      <!-- 定义名字为skill的包,该Action继承自default的包 --> 
    52. 
    53.      <package name="skill" extends="default" namespace="/skill"> 
    54. 
    55.          <!-- 定义默认的拦截器引用 --> 
    56. 
    57.          <default-interceptor-ref name="crudStack"/> 
    58. 
    59.          <!-- 定义名为Edit的Action,该action对应的处理类为superSkillAction --> 
    60. 
    61.          <action name="Edit" class="super.SkillAction"> 
    62. 
    63.              <result>/empmanager/editSkill.jsp</result> 
    64. 
    65.              <interceptor-ref name="params"/> 
    66. 
    67.              <interceptor-ref name="basicStack"/> 
    68. 
    69.          </action> 
    70. 
    71.          <!-- 定义名为Save的Action,该action对应的处理类为super.SkillAction,使用save方法作为处理的方法 --> 
    72. 
    73.          <action name="Save" class="super.SkillAction" method="save"> 
    74. 
    75.              <result name="input">/empmanager/editSkill.jsp</result> 
    76. 
    77.              <result name="redirect">edit.action?skillName=${currentSkill.name}</result> 
    78. 
    79.          </action> 
    80. 
    81.          <!-- 定义名为Delete的Action,该Action对应的处理类为supermos.SkillAction,使用delete方法作为处理方法 --> 
    82. 
    83.          <action name="Delete" class="supermos.SkillAction"> 
    84. 
    85.              <result name="error">/empmanager/editSkill.jsp</result> 
    86. 
    87.              <result type="redirect">edit.action?SkillName=${currentSkill.name}</result> 
    88. 
    89.          </action> 
    90. 
    91.      </package> 
    92. 
    93.  </struts> 
    <?xml version="1.0" encoding="UTF-8"?>

    <!DOCTYPE struts PUBLIC

      "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN"

      "http://struts.apache.org/dtds/struts-2.1.dtd">

      <struts>

          <!-- 配置第一个包,该包的名字为default继承自struts-default -->

          <package name="default" extends="struts-default">

              <!-- 下面定义了拦截器部分 -->

              <interceptors>

                  <!-- 定义拦截器栈 -->

                  <interceptor-stack name="crudStack">

                      <interceptor-ref name="params"/>

                      <interceptor-ref name="defaultStack"/>

                  </interceptor-stack>

              </interceptors>

              <default-action-ref name="showcase"/>

              <!-- 定义一个Action,该Action直接映射到showcase.jsp页面 -->

              <action name="Showcase">

                  <result>showcase.jsp</result>

              </action>

              <!-- 定义了一个Action,该Action类为com.opensymphony.webwork.showcase.DateAction -->

              <action name="Date" class="supermos.DateAction">

                  <result name="success">/date.jsp</result>

              </action>

          </package>

          <!-- 定义名字为skill的包,该Action继承自default的包 -->

          <package name="skill" extends="default" namespace="/skill">

              <!-- 定义默认的拦截器引用 -->

              <default-interceptor-ref name="crudStack"/>

              <!-- 定义名为Edit的Action,该action对应的处理类为superSkillAction -->

              <action name="Edit" class="super.SkillAction">

                  <result>/empmanager/editSkill.jsp</result>

                  <interceptor-ref name="params"/>

                  <interceptor-ref name="basicStack"/>

              </action>

              <!-- 定义名为Save的Action,该action对应的处理类为super.SkillAction,使用save方法作为处理的方法 -->

              <action name="Save" class="super.SkillAction" method="save">

                  <result name="input">/empmanager/editSkill.jsp</result>

                  <result name="redirect">edit.action?skillName=${currentSkill.name}</result>

              </action>

              <!-- 定义名为Delete的Action,该Action对应的处理类为supermos.SkillAction,使用delete方法作为处理方法 -->

              <action name="Delete" class="supermos.SkillAction">

                  <result name="error">/empmanager/editSkill.jsp</result>

                  <result type="redirect">edit.action?SkillName=${currentSkill.name}</result>

              </action>

          </package>

      </struts>

    在上面的配置文件当中,配置了两个包,其中定义名为skill的包的时候,还制定了改包的命名空间skill,其中skill用于指定某个包对应的命名空间.

    4)  命名空间的配置
    考虑到在同一个Web应用中,需要同名的Action,Struts2以命名空间的方式来管理Action,在同一个命名空间中不能有同名的Action,不同的命名空间中可以存在同名的Action.

    Struts2不支持为单独的Action设置命名空间,而是通过为包指定namespace属性来为包下面的所有的Action指定共同的命名空间.

    看下面struts.xml配置文件的源代码:

    //TODO

    在上面的struts.xml配置文件当中,配置了两个包,supermos和get包,配置get包的时候指定了该包的命名空间为/book.

    对于名字为supermos的包而言,没有指定namespace属性,如果某个包没有指定namespace属性,既该包使用了默认的命名空间,则默认的命名空间总是””.

    当某个包指定了命名空间之后,该包下的所有的Action处理的URL应该是命名空间+Action名,以上名为get的包为例,该包下包含了名为getBooks的Action,则该Action处理的URL为:

    http://localhost:8080/namespace/book/GetBooks.action

    从上面可以看出,Struts2命名空间的作用类似于Struts1里面模块的作用.

    (Struts2的命名空间的作用就类似于Struts1里模块的作用,它允许以模块化的方式来组织Action)

    除此之外,Struts2还可以显示指定根命名空间,通过设置某个包的namespace=”/”来制定跟命名空间.

    如果请求为/barspace/bar.action,系统会首先去查找/barspace命名空间里面的名字为bar的Action,如果在该命名空间里面找到对应的Action,则使用该Action处理该请求,否则,系统将到默认命名空间里面找到名字为bar的action,如果找到对应的Action,则使用该Action处理用户请求,如果两个命名空间里面都找不到名字为bar的Action,则系统出现错误.

    (默认空间里面的Action可以处理任何模块下的Action请求,意思是说,如果存在URL为/barspace/bar.action的请求,并且/barspace的命名空间下没有名为bar的Action,则命名空间下名为bar的Action也会处理用户请求.)

    如果请求为/login.action,系统会在根命名空间下(“/”)查找名字为login的Action,如果在根命名空间下找到了名字为login的Action,则由该Action处理用户的请求,否则系统将转入默认空间中查找名字为login的Action,如果默认的命名空间中有名字为login的Action,则由该Action处理用户请求,如果两个命名空间里面都找不到名字为login的Action,那么系统将会出现错误.

    (命名空间只有一个级别,如果请求的URL是/bookservice/search/get.action,系统将会首先在/bookservice/search的命名空间下查找名字为get的Action,如果在该命名空间中找到名字为get的Action,则由该Action处理用户的请求,如果在该命名空间中没有找到get的Action,系统将会直接进入默认的命名空间中查找名字为get的Action,而不会在/bookService的命名空间下查找名字为get的Action).

    5)  包含配置
    包含配置体现的是软件工程中的”分而治之”的原则.

    Struts2允许将一个配置文件分解成多个配置文件,从而提供配置文件的可读性.一旦我们通过多个struts.xml文件来配置Action,但是Struts2默认只加载WEB-INF/classes下面的struts.xml,我们就必须通过struts.xml文件来包含其他的配置文件.

    在struts.xml文件中包含其他配置文件通过<include…/>元素来完成,配置<include…/>元素需要指定一个必须的file属性,该属性指定了被包含配置文件的文件名,西面是一个struts.xml文件中包含了4个配置文件的代码片段:

    view plaincopy to clipboardprint?
    01.<?xml version="1.0" encoding="UTF-8"?> 
    02. 
    03. <!DOCTYPE struts PUBLIC   
    04. 
    05. "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"  
    06. 
    07. "http://struts.apache.org/dtds/struts-2.0.dtd"> 
    08. 
    09. <struts> 
    10. 
    11.     <include file="struts-user1.xml"/> 
    12. 
    13.     <include file="struts-user2.xml"/> 
    14. 
    15.     <include file="struts-user3.xml"/> 
    16. 
    17.     <include file="struts-user4.xml"/> 
    18. 
    19.     <include file="struts-user5.xml"/> 
    20. 
    21. </struts> 
    <?xml version="1.0" encoding="UTF-8"?>

     <!DOCTYPE struts PUBLIC

     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"

     "http://struts.apache.org/dtds/struts-2.0.dtd">

     <struts>

         <include file="struts-user1.xml"/>

         <include file="struts-user2.xml"/>

         <include file="struts-user3.xml"/>

         <include file="struts-user4.xml"/>

         <include file="struts-user5.xml"/>

     </struts>
     


     

    被包含的struts-user1.xml,struts-user2.xml等配置文件,是标准的Struts2的配置文件,一样都包含了DTD信息,Struts2配置文件的根元素等信息.通常,将Struts2的所有的配置文件都放在Web应用的WEB-INF/classes路径的下面,struts.xml文件包含了其他的配置文件,Struts2框架自动的加载struts.xml文件的时候,从而完成了加载所有的配置文件的信息.

    6)  包拦截器配置
    拦截器其实就是AOP(面向切面编程)的编程思想,拦截器允许在Action处理之前,或者Action处理结束之后,插入开发者自己定义的代码.

    在很多时候,我们需要在多个Action进行相同的操作,比如说权限的控制,此处就可以使用拦截器来检查用户是否登录,用户的权限是否足够(当然,这个地方也可以借助spring的Aop框架来完成).通常,使用拦截器可以完成如下的几个操作:

    l         进行权限的控制(检查浏览者是否登录,并且有足够的访问权限)

    l         跟踪日志(记录每个浏览者所请求的每个Action)

    l         跟踪系统的性能瓶颈(我们可以通过记录每个Action开始处理的时间和处理结束的时间,从而获得耗时比较长的Action)

    Struts2也允许将多个拦截器组合在一起,从而形成一个拦截器栈.一个拦截器栈可以包含多个拦截器,多个拦截器组成一个拦截器栈,对于Struts2系统而言,多个拦截器组成的拦截器栈对外也表现成一个拦截器.

    (可以认为多个拦截器组成的拦截器栈是一个比较大的拦截器)

    定义拦截器栈之前,必须首先定义组成拦截器栈的多个拦截器,Struts2吧拦截器栈当成拦截器来处理,因此拦截器栈和拦截器都放在<interceptors…/>元素中进行定义.

    下面是拦截器的定义片段:

    view plaincopy to clipboardprint?
    01.<?xml version="1.0" encoding="UTF-8"?> 
    02. 
    03. <!DOCTYPE struts PUBLIC   
    04. 
    05. "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"  
    06. 
    07. "http://struts.apache.org/dtds/struts-2.0.dtd"> 
    08. 
    09. <struts> 
    10. 
    11.     <package name="supermos" extends="struts-default"> 
    12. 
    13.         <interceptors> 
    14. 
    15.             <!-- 定义权限检查的拦截器 --> 
    16. 
    17.             <interceptor name="authority" class="super.AuthrityInterceptor"/> 
    18. 
    19.             <!-- 定义日志记录的拦截器 --> 
    20. 
    21.             <interceptor name="log" class="super.LogInterceptor"/> 
    22. 
    23.             <!-- 定义一个拦截器栈 --> 
    24. 
    25.             <interceptor-stack name="authorityandlog"> 
    26. 
    27.                 <!-- 定义该拦截器里面包含的authority拦截器 --> 
    28. 
    29.                 <interceptor-ref name="authority"/> 
    30. 
    31.                 <!-- 定义该拦截器里面包含的log拦截器 --> 
    32. 
    33.                 <interceptor-ref name="log"/> 
    34. 
    35.             </interceptor-stack> 
    36. 
    37.         </interceptors> 
    38. 
    39.     </package> 
    40. 
    41. </struts> 
    42. 
    43.在上面的拦截器配置片段中,定义了两个拦截器,并且将两个拦截器组成一个拦截器栈,一旦定义了拦截器和拦截器栈以后,在Action中使用拦截器或者拦截器栈的方式是相同的.  
    44. 
    45.<?xml version="1.0" encoding="UTF-8"?> 
    46. 
    47. <!DOCTYPE struts PUBLIC   
    48. 
    49. "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"  
    50. 
    51. "http://struts.apache.org/dtds/struts-2.0.dtd"> 
    52. 
    53. <struts> 
    54. 
    55.     <package name="supermos" extends="struts-default"> 
    56. 
    57.         <interceptors> 
    58. 
    59.             <!-- 定义权限检查的拦截器 --> 
    60. 
    61.             <interceptor name="authority" class="super.AuthrityInterceptor"/> 
    62. 
    63.             <!-- 定义日志记录的拦截器 --> 
    64. 
    65.             <interceptor name="log" class="super.LogInterceptor"/> 
    66. 
    67.             <!-- 定义一个拦截器栈 --> 
    68. 
    69.             <interceptor-stack name="authorityandlog"> 
    70. 
    71.                 <!-- 定义该拦截器里面包含的authority拦截器 --> 
    72. 
    73.                 <interceptor-ref name="authority"/> 
    74. 
    75.                 <!-- 定义该拦截器里面包含的log拦截器 --> 
    76. 
    77.                 <interceptor-ref name="log"/> 
    78. 
    79.             </interceptor-stack> 
    80. 
    81.         </interceptors> 
    82. 
    83.         <action name="MyAction" class="supermos.MyAction"> 
    84. 
    85.             <result name="success">/success.jsp</result> 
    86. 
    87.             <interceptor-ref name="authorityandlog"/> 
    88. 
    89.         </action> 
    90. 
    91.     </package> 
    92. 
    93. </struts> 
    <?xml version="1.0" encoding="UTF-8"?>

     <!DOCTYPE struts PUBLIC

     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"

     "http://struts.apache.org/dtds/struts-2.0.dtd">

     <struts>

         <package name="supermos" extends="struts-default">

             <interceptors>

                 <!-- 定义权限检查的拦截器 -->

                 <interceptor name="authority" class="super.AuthrityInterceptor"/>

                 <!-- 定义日志记录的拦截器 -->

                 <interceptor name="log" class="super.LogInterceptor"/>

                 <!-- 定义一个拦截器栈 -->

                 <interceptor-stack name="authorityandlog">

                     <!-- 定义该拦截器里面包含的authority拦截器 -->

                     <interceptor-ref name="authority"/>

                     <!-- 定义该拦截器里面包含的log拦截器 -->

                     <interceptor-ref name="log"/>

                 </interceptor-stack>

             </interceptors>

         </package>

     </struts>

    在上面的拦截器配置片段中,定义了两个拦截器,并且将两个拦截器组成一个拦截器栈,一旦定义了拦截器和拦截器栈以后,在Action中使用拦截器或者拦截器栈的方式是相同的.

    <?xml version="1.0" encoding="UTF-8"?>

     <!DOCTYPE struts PUBLIC

     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"

     "http://struts.apache.org/dtds/struts-2.0.dtd">

     <struts>

         <package name="supermos" extends="struts-default">

             <interceptors>

                 <!-- 定义权限检查的拦截器 -->

                 <interceptor name="authority" class="super.AuthrityInterceptor"/>

                 <!-- 定义日志记录的拦截器 -->

                 <interceptor name="log" class="super.LogInterceptor"/>

                 <!-- 定义一个拦截器栈 -->

                 <interceptor-stack name="authorityandlog">

                     <!-- 定义该拦截器里面包含的authority拦截器 -->

                     <interceptor-ref name="authority"/>

                     <!-- 定义该拦截器里面包含的log拦截器 -->

                     <interceptor-ref name="log"/>

                 </interceptor-stack>

             </interceptors>

             <action name="MyAction" class="supermos.MyAction">

                 <result name="success">/success.jsp</result>

                 <interceptor-ref name="authorityandlog"/>

             </action>

         </package>

     </struts>

    上面的配置文件中定义了一个名字为MyAction的Action,并且在该Action中引用了一个名字为authorityandlog的拦截器栈,对于Action而言,引用拦截器和引用拦截器栈的用法是完全一样的.


    本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/ziwen00/archive/2009/09/02/4510149.aspx

  • 相关阅读:
    k3 cloud中获取自己开发的单据
    k3 cloud列表中出现很多空白
    k3 cloud支付申请单下推付款单时候提示未将对象引用设置到对象的实例
    k3 cloud出现应收单下推收款单,把收款单是结算方式修改成银行承兑汇票之后保存提示:收款单明细中结算方式为票据业务的实收金额之和不等于票据的当前占用金额之和,请检查数据!
    k3 cloud中出现合计和汇总以后没有显示出来,合价要新增一行以后才出现值
    共享打印机
    k3 cloud总账凭证点击保存的时候提示未将对象引用到对应的实例
    k3 cloud成本调整单引入单据后,再做出库成本核算。成本调整单列表已审核的单据消失,非已审核的单据还在,这是出库成本核算设置参数的问题吗?
    K3 cloud选单时候必须把必录的数据录完以后才可以选单
    k3 cloud成本调整单提示期末余额不存在调整单分录的维度,请先出库核算确认是否存在核算维度的数据
  • 原文地址:https://www.cnblogs.com/pocter/p/3684560.html
Copyright © 2011-2022 走看看