Struts2(配置说起I)

为什么要有struts.xml文件
struts.xml文件是整个Struts2框架的核心。 struts.xml文件内定义了Struts2的系列Action,定义Action时,指定该Action的实现类,并定义该Action处理结果与视图资源之间的映射关系。
struts.xml
struts.properties不是必须要的,struts.properties文件的内容均可在struts.xml中以<constant name="" value=""></constant>加载

default.properties重要配置:(括号内为默认值)
struts.configuration = (org.apache.Struts2.config.DefaultConfiguration)
该属性指定加载Struts 2配置文件的配置文件管理器。该属性的默认值是org.apache.Struts2.config.DefaultConfiguration,这是Struts 2默认的配置文件管理器。如果需要实现自己的配置管理器,开发者则可以实现一个实现Configuration接口的类,该类可以自己加载Struts 2配置文件。

struts.i18n.encoding =(UTF-8)
指定Web应用的默认编码集。该属性对于处理中文请求参数非常有用,对于获取中文请求参数值,应该将该属性值设置为GBK或者GB2312。 提示 当设置该参数为GBK时,相当于调用HttpServletRequest的setCharacterEncoding方法。

struts.objectFactory = (spring)
也可以提供一个 com.opensymphony.xwork2.ObjectFactory 的子类。

struts.objectFactory.spring.autoWrite =(name)
即默认根据Bean的name属性自动装配。还有 type, auto,与constructor

struts.objectFactory.spring.useClassCache =(true)
该属性指定整合Spring框架时,是否缓存Bean实例,该属性只允许使用true和false两个属性值,它的默认值是true。通常不建议修改该属性值。

struts.multipart.parser =(jakarta)
该属性指定处理multipart/form-data的MIME类型(文件上传)请求的框架,该属性支持cos、pell和jakarta等属性值,即分别对应使用cos的文件上传框架、pell上传及common-fileupload文件上传框架。不是默认的要单独加入上传所依赖的包。

struts.multipart.saveDir = (javax.servlet.context.tempdir)
该属性指定上传文件的临时保存路径.

struts.multipart.maxSize=(2097152)(20M)
该属性指定Struts 2文件上传中整个请求内容允许的最大字节数.

struts.custom.properties
该属性指定Struts 2应用加载用户自定义的属性文件,该自定义属性文件指定的属性不会覆盖struts.properties文件中指定的属性。如果需要加载多个自定义属性文件,多个自定义属性文件的文件名以英文逗号(,)隔开。

struts.mapper.class=(org.apache.struts2.dispatcher.mapper.DefaultActionMapper)
指定将HTTP请求映射到指定Action的映射器,Struts 2提供了默认的映射器:org.apache.struts2.dispatcher.mapper.DefaultActionMapper。默认映射器根据请求的前缀与Action的name属性完成映射。

struts.action.extension =(action,,)
该属性指定需要Struts 2处理的请求后缀,该属性的默认值是action,即所有匹配*.action的请求都由Struts 2处理。如果用户需要指定多个请求后缀,则多个后缀之间以英文逗号(,)隔开

struts.serve.static.browserCache =(true)
该属性设置浏览器是否缓存静态内容。当应用处于开发阶段时,我们希望每次请求都获得服务器的最新响应,则可设置该属性为false。

struts.enable.DynamicMethodInvocation =(false)
该属性设置Struts 2是否支持动态方法调用,该属性的默认值是true。

struts.enable.SlashesInActionNames =(false)
该属性设置Struts 2是否允许在Action名中使用斜线.

struts.tag.altSyntax =(true)
该属性指定是否允许在Struts 2标签中使用表达式语法,因为通常都需要在标签中使用表达式语法,故此属性应该设置为true,该属性的默认值是true。

struts.devMode=(false)
该属性设置Struts 2应用是否使用开发模式。如果设置该属性为true,则可以在应用出错时显示更多、更友好的出错提示。该属性只接受true和flase两个值

struts.i18n.reload =(false)
该属性设置是否每次HTTP请求到达时,系统都重新加载资源文件。该属性默认值是false。在开发阶段将该属性设置为true会更有利于开发,但在产品发布阶段应将该属性设置为false。

struts.ui.theme =(xhtml)
该属性指定视图标签默认的视图主题,该属性的默认值是xhtml。

struts.ui.templateDir
该属性指定视图主题所需要模板文件的位置,该属性的默认值是template,即默认加载template路径下的模板文件

struts.ui.templateSuffix =(ftl)
该属性指定模板文件的后缀,该属性还允许使用ftl、vm或jsp,分别对应FreeMarker、Velocity和JSP模板。

struts.configuration.xml.reload =(false)
该属性设置当struts.xml文件改变后,系统是否自动重新加载该文件。

struts.velocity.configfile=(locity.properties)
该属性指定Velocity框架所需的velocity.properties文件的位置。该属性的默认值为velocity.properties

struts.velocity.contexts
该属性指定Velocity框架的Context位置,如果该框架有多个Context,则多个Context之间以英文逗号(,)隔开。

struts.velocity.toolboxlocation
该属性指定Velocity框架的toolbox的位置

struts.url.includeParams =(none)
该属性指定Struts 2生成URL时是否包含请求参数。该属性接受none、get和all三个属性值,分别对应于不包含、仅包含GET类型请求参数和包含全部请求参数。

struts.custom.i18n.resources
该属性指定Struts 2应用所需要的国际化资源文件,如果有多份国际化资源文件,则多个资源文件的文件名以英文逗号(,)隔开。

struts.dispatcher.parametersWorkaround =(false)
对于某些Java EE服务器,不支持HttpServlet Request调用getParameterMap()方法,此时可以设置该属性值为true来解决该问题。对于WebLogic、Orion和OC4J服务器,通常应该设置该属性为true。


org.apache.struts2.views.freemarker.FreemarkerManager =(true)
这是Struts 2内建的FreeMarker管理器。struts.freemarker.wrapper.altMap 该属性只支持true和false两个属性值.

struts.xslt.nocache =(false)
该属性指定XSLT Result是否使用样式表缓存。当应用处于开发阶段时,该属性通常被设置为true;当应用处于产品使用阶段时,该属性通常被设置为false。


1.开发模式下:如果修改了struts.xml文件,你不用重启web容器,原因是开发模式下,struts在处理每一个请求时去检查一遍这人文件的时间戳,如果这个文件的时间戳从它最后一次被 加载以来发生了变化,struts就会重新加载这个文件。
设置成开发模式有以下几个方法:
在默认的default.properites文件内已设成默认struts.devMode = false
从struts2的原码中可以看到这样的注释
### Struts default properties
###(can be overridden by a struts.properties file in the root of the classpath)
###
所以第一方法是:在classpath的根目录下新建一个名叫struts.properties 的文件去覆盖原来那个默认值
设置成
struts.devMode = true
第二个方法是:
在struts.xml中增加
   <struts ...>
<constant name="struts.devMode" value="true">
</struts>


第三个方法是:
web.xml中加入初始化参数
<filter>
<filter-name>struts</filter-name>
<filter-class>
org.apache.struts2.dispatcher.FilterDispatcher
</filter-class>
<init-param>
<param-name>struts.devMode</param-name>
<param-value>true</param-value>
</init-param>
</filter>



2.你可能习惯了用struts1.x,请求以.do结尾,struts2同样可以实现过滤*.do结尾 (struts2默认是以.action)的请求,只要
如上面所述在其中一个地方把struts.action.extension改一下即可:
struts.action.extension = do
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值