struts配置文件详解

来源:互联网 发布:淘宝点客服没反应 编辑:程序博客网 时间:2024/06/18 05:26

<include>标签

可以将一个struts.xml文件拆分成多个struts配置文件,然后再struts.xml文件中使用include标签引入拆分出来的配置文件。

<constant>

  1. <!--指定Web应用的默认编码集.该属性对于处理中文请求参数非常有用,对于获取中文请求参数值,应该将该属性值设置为GBK或者GB2312;   
  2.            提示:当设置该参数为GBK时,相当于调用HttpServletRequest的setCharacterEncoding方法. >  
  3.  <constant name="struts.i18n.encoding" value="UTF-8" />  
  4.   
  5.        <!--指定Struts 2默认的ObjectFactory Bean,该属性默认值是spring. >  
  6.  <constant name="struts.objectFactory" value="spring" />  
  7.   
  8.        <!--指定Spring框架的自动装配模式, 该属性的默认值是name, 即默认根据Bean的name属性自动装配. >  
  9.  <constant name="struts.objectFactory.spring.autoWire" value="name" />  
  10.   
  11.        <!--该属性指定整合Spring框架时,是否缓存Bean实例,该属性只允许使用true和false两个属性值,它的默认值是true.通常不建议修改该属性值. >  
  12.  <constant name="struts.objectFactory.spring.useClassCache" value="true" />  
  13.   
  14.        <!--该属性指定处理multipart/form-data的MIME类型(文件上传)请求的框架,该属性支持cos,pell和jakarta等属性值, 即分别对应使用cos的文件上传框架,pell上传及common-fileupload文件上传框架.该属性的默认值为jakarta.   
  15.            注意:如果需要使用cos或者pell的文件上传方式,则应该将对应的JAR文件复制到Web应用中.例如,使用cos上传方式,则需要自己下载cos框架的JAR文件,并将该文件放在WEB-INF/lib路径下. >  
  16.  <constant name="struts.multipart.parser" value="jakarta" />  
  17.   
  18.        <!--该属性指定上传文件的临时保存路径,该属性的默认值是javax.servlet.context.tempdir. >  
  19.  <constant name="struts.multipart.saveDir" value="" />  
  20.   
  21.        <!--该属性指定Struts 2文件上传中整个请求内容允许的最大字节数. >  
  22.  <constant name="struts.multipart.maxSize" value="1000000000000" />  
  23.   
  24.        <!--该属性指定需要Struts 2处理的请求后缀,该属性的默认值是action,即所有匹配*.action的请求都由Struts 2处理.如果用户需要指定多个请求后缀,则多个后缀之间以英文逗号(,)隔开. >  
  25.  <constant name="struts.action.extension" value="do" />  
  26.   
  27.        <!--该属性设置是否通过JAR文件提供静态内容服务,该属性只支持true和false属性值,该属性的默认属性值是true. >  
  28.  <constant name="struts.serve.static" value="true" />  
  29.   
  30.        <!--该属性设置浏览器是否缓存静态内容.当应用处于开发阶段时,我们希望每次请求都获得服务器的最新响应,则可设置该属性为false. >  
  31.  <constant name="struts.serve.static.browserCache" value="true" />  
  32.   
  33.        <!--该属性设置Struts 2应用是否使用开发模式.如果设置该属性为true,则可以在应用出错时显示更多、更友好的出错提示.该属性只接受true和flase两个值,该属性的默认值是false.通常,应用在开发阶段,将该属性设置为true,当进入产品发布阶段后,则该属性设置为false. >  
  34.  <constant name="struts.devMode" value="false" />  
  35.   
  36.        <!--该属性设置是否每次HTTP请求到达时,系统都重新加载资源文件(允许国际化文件重载).该属性默认值是false.在开发阶段将该属性设置为true会更有利于开发,但在产品发布阶段应将该属性设置为false.   
  37.            提示:开发阶段将该属性设置了true,将可以在每次请求时都重新加载国际化资源文件,从而可以让开发者看到实时开发效果;产品发布阶段应该将该属性设置为false,是为了提供响应性能,每次请求都需要重新加载资源文件会大大降低应用的性能. >  
  38.  <constant name="struts.i18n.reload" value="false" />  
  39.   
  40.        <!--该属性指定视图标签默认的视图主题,该属性的默认值是xhtml. >  
  41.  <constant name="struts.ui.theme" value="simple" />  
  42.   
  43.        <!--该属性指定模板文件的后缀,该属性的默认属性值是ftl.该属性还允许使用ftl、vm或jsp,分别对应FreeMarker、Velocity和JSP模板. >  
  44.  <constant name="struts.ui.templateSuffix" value="ftl" />  
  45.   
  46.        <!--该属性设置当struts.xml文件改变后,系统是否自动重新加载该文件.该属性的默认值是false. >  
  47.  <constant name="struts.configuration.xml.reload" value="false" />  
  48.   
  49.        <!--该属性指定Struts 2应用所需要的国际化资源文件,如果有多份国际化资源文件,则多个资源文件的文件名以英文逗号(,)隔开. >  
  50.  <constant name="struts.custom.i18n.resources" value="nationz" />  
  51.   
  52.        <!--对于某些Java EE服务器,不支持HttpServlet Request调用getParameterMap()方法,此时可以设置该属性值为true来解决该问题.该属性的默认值是false.对于WebLogic、Orion和OC4J服务器,通常应该设置该属性为true. >  
  53.  <constant name="struts.dispatcher.parametersWorkaround" value="false" />  
  54.   
  55.        <!--指定是否缓存FreeMarker模版。默认值false。>  
  56.  <constant name="struts.freemarker.templatesCache" value="true" />  
  57.   
  58.        <!--该属性只支持true和false两个属性值,默认值是true.通常无需修改该属性值. >  
  59.  <constant name="struts.freemarker.wrapper.altMap" value="true" />  
  60.   
  61.        <!--该属性指定XSLT Result是否使用样式表缓存.当应用处于开发阶段时,该属性通常被设置为true;当应用处于产品使用阶段时,该属性通常被设置为false. >  
  62.  <constant name="struts.xslt.nocache" value="false" />  
  63.   
  64.        <!--该属性指定Struts 2框架默认加载的配置文件,如果需要指定默认加载多个配置文件,则多个配置文件的文件名之间以英文逗号(,)隔开.该属性的默认值为struts-default.xml,struts-plugin.xml,struts.xml,看到该属性值,所以应该明白为什么Struts 2框架默认加载struts.xml文件了. >  
  65.  <constant name="struts.configuration.files" value="struts-default.xml,struts-plugin.xml" />  
  66.   
  67.        <!--设置映射器是否总是选择完整的名称空间。该属性的默认值时false。>  
  68.  <constant name="struts.mapper.alwaysSelectFullNamespace" value="false" />  
  69.   
  70.        <!--设置Convention插件定位视图资源的根路径。默认值为/WEB-INF/content>  
  71.  <constant name="struts.convention.result.path" value="/WEB-INF/content/" />  
  72.    
  73.        <!--Convention插件以该常量指定包作为根包>  
  74.  <constant name="struts.convention.action.package" value="default" />  
  75.    
  76.        <!--是否从包中搜索Action>  
  77.  <constant name="struts.convention.action.disableScanning" value="false"/>  
  78.          
  79.        <!-- 官方只说明在jboss下需要设置,情况不明 -->  
  80.  <constant name="struts.convention.exclude.parentClassLoader" value="true" />   
  81.  <constant name="struts.convention.action.fileProtocols" value="jar,zip" />  
  82.   
  83.        <!--包括哪些jar包中的action。逗号分割字符串。>  
  84.  <constant name="struts.convention.action.includeJars" value=".*?/_wl_cls_gen.*?jar(!/)?" />  
  85.   
  86.        <!--确定搜索包的路径。只要是结尾为action的包都要搜索。>  
  87.  <constant name="struts.convention.package.locators" value="action" />  

<package>

1、包属性介绍

在Struts2框架中是通过包来管理action、result、interceptor、interceptor-stack等配置信息的。包属性如下:

属性

是否必需

描述

name是包名,作为其它包应用本包的标记extends否设置本包继承其它包namespace否设置包的命名空间abstact否设置为抽象包

2、extends属性的详解

  • 当一个包通过配置extends属性继承了另一个包的时候,该包将会继承父包中所有的配置,包括action、result、interceptor等。
  • 由于包信息的获取是按照配置文件的先后顺序进行的,所以父包必须在子包之前被定义。
  • 通常我们配置struts.xml的时候,都继承一个名为“struts-default.xml”的包,这是struts2中内置的包。

3、namespace的详解


namespace主要是针对大型项目中Action的管理,更重要的是解决Action重名问题,因为不在同一个命名空间的Action可以使用相同的Action名的。

3、action与result


1、<action>属性介绍

属性名称

是否必须

功能描述

name是请求的Action名称class否Action处理类对应具体路径method否指定Action中的方法名converter否指定Action使用的类型转换器

如果没有指定method则默认执行Action中的execute方法

2、<result>属性介绍

属性名称

是否必须

功能描述

name否对应Action返回逻辑视图名称,默认为successtype否返回结果类型,默认为dispatcher

3通配符

1
2
3
4
5
<packagename="wwfy"extends="struts-default">
    <actionname="test*"class="wwfy.action.test{1}">
        <resultname="result{1}">/result{1}.jsp</result>
    </action>
</package>

4、访问Action方法的另一种实现方式

在Struts2中如果要访问Action中的指定方法,还可以通过改变URL请求来实现,将原本的“Action名称.action”改为“Action名称!方法名称.action”在struts.xml中就不需要指定方法名了。


5<exception-mapping>与<global-exception-mapping>


这两个标签都是用来配置发生异常时对应的视图信息的,只不过一个是Action范围的,一个是包范围的,当同一类型异常在两个范围都被配置时,Action范围的优先级要高于包范围的优先级.这两个标签包含的属性也是一样的:

属性名称

是否必须

功能描述

name否用来表示该异常配置信息result是指定发生异常时显示的视图信息,这里要配置为逻辑视图exception是指定异常类型

6、<default-class-ref>

当我们在配置Action的时候,如果没有为某个Action指定具体的class值时,系统将自动引用<default-class-ref>标签中所指定的类。在Struts2框架中,系统默认的class为ActionSupport,该配置我们可以在xwork的核心包下的xwork-default.xml文件中找到。

有特殊需要时,可以手动指定默认的class

7、<default-action-ref>

如果在请求一个没有定义过的Action资源时,系统就会抛出404错误。这种错误不可避免,但这样的页面并不友好。我们可以使用<default-action-ref>来指定一个默认的Action,如果系统没有找到指定的Action,就会指定来调用这个默认的Action。

8、<default-interceptor-ref>

该标签用来设置整个包范围内所有Action所要应用的默认拦截器信息。事实上我们的包继承了struts-default包以后,使用的是Struts的默认设置。我们可以在struts-default.xml中找到相关配置:

?
1
<default-interceptor-refname="defaultStack"/>

 

在实际开发过程中,如果我们有特殊的需求是可以改变默认拦截器配置的。当时一旦更改这个配置,“defaultStack”将不再被引用,需要手动最加。

9、<interceptors>


通过该标签可以向Struts2框架中注册拦截器或者拦截器栈,一般多用于自定义拦截器或拦截器栈的注册。该标签使用方法如下:

?
1
2
3
4
5
6
<interceptors>
    <interceptorname="拦截器名"class="拦截器类"/>
    <interceptor-stackname="拦截器栈名">
        <interceptor-refname="拦截器名">
    </interceptor-stack>
</interceptors>

10、<interceptor-ref>

通过该标签可以为其所在的Action添加拦截器功能。当为某个Action单独添加拦截器功能后,<default-interceptor-ref>中所指定的拦截器将不再对这个Action起作用。


11、<global-results>

该标签用于设置包范围内的全局结果集。在多个Action返回相同逻辑视图的情况下,可以通过<global-results>标签统一配置这些物理视图所对应的逻辑视图。








原创粉丝点击