struts2.0配置文件、常量配置详解 通常struts2加载struts2常量的顺序如下:
1.struts-default.xml:该文件保存在struts2-core-2.0.6.jar文件中。
2.struts-plugin.xml:该文件保存在struts2-Xxx-2.0.6.jar等Struts2插件JAR文件中。
3.struts.xml:该文件是Web应用默认的Struts2配置文件。
4.struts.properties:该文件是Web应用默认的Struts2配置文件。
5.web.xml:该文件是Web应用的配置文件。
如果在多个文件中配置了同一个Struts2常量,则后一个文件中的配置的常量值会覆盖前面文件中配置的常量值。
在不同文件中配置常量的方式是不一样的,但不管哪个文件中,配置Struts2常量都要指定两个属性:常量name和常量value。
推荐在struts.xml文件中配置Struts2常量。
此处只加载了前三个配置文件,这是在常量struts.configuration.files中配置的。该属性指定Struts2框架默认加载的配置文件,如果需要指定默认加载多个配置文件,则多个配置文件的文件名之间以英文逗号(,)隔开。该属性的默认值为struts-default.xml,struts-plugin.xml,struts.xml,这就是上图中加载的三个配置文件。
Struts2常量的具体用法实例
Xml代码
- <?xmlversion="1.0"encoding="UTF-8"?>
- <!DOCTYPEstrutsPUBLIC
- "-//ApacheSoftwareFoundation//DTDStrutsConfiguration2.0//EN"
- "http://struts./dtds/struts-2.0.dtd">
-
- <struts>
- <!--指定Web应用的默认编码集,相当于调用HttpServletRequest的setCharacterEncoding方法-->
- <constant name="struts.i18n.encoding" value="UTF-8"/>
-
- <!--
- 该属性指定需要Struts2处理的请求后缀,该属性的默认值是action,即所有匹配*.action的请求都由Struts2处理。
- 如果用户需要指定多个请求后缀,则多个后缀之间以英文逗号(,)隔开。
- -->
- <constant name="struts.action.extension" value="do"/>
-
- <!--设置浏览器是否缓存静态内容,默认值为true(生产环境下使用),开发阶段最好关闭-->
- <constant name="struts.serve.static.browserCache" value="false"/>
-
- <!--当struts的配置文件修改后,系统是否自动重新加载该文件,默认值为false(生产环境下使用),开发阶段最好打开-->
- <constant name="struts.configuration.xml.reload" value="true"/>
-
- <!--开发模式下使用,这样可以打印出更详细的错误信息-->
- <constant name="struts.devMode" value="true"/>
-
- <!--默认的视图主题-->
- <constant name="struts.ui.theme" value="simple"/>
-
- <!--spring托管-->
- <constant name="struts.objectFactory" value="spring"/>
-
- <!--
- 指定加载struts2配置文件管理器,默认为org.apache.struts2.config.DefaultConfiguration
- 开发者可以自定义配置文件管理器,该类要实现Configuration接口,可以自动加载struts2配置文件。
- -->
- <constant name="struts.configuration"
- value="org.apache.struts2.config.DefaultConfiguration"/>
-
- <!--设置默认的locale和字符编码-->
- <constant name="struts.locale" value="zh_CN"/>
- <constant name="struts.i18n.encoding" value="GBK"/>
-
- <!--指定Struts的工厂类-->
- <constant name="struts.objectFactory"
value="spring"></constant>
-
- <!--
- 指定spring框架的装配模式,装配方式有:name,type,auto,andconstructor(name
- 是默认装配模式)
- -->
- <constant name="struts.objectFactory.spring.autoWire"
value="name"/>
-
- <!--该属性指定整合spring时,是否对bean进行缓存,值为trueor/false,默认为true-->
- <constant name="struts.objectFactory.spring.useClassCache"/>
-
- <!--指定类型检查,包含tiger和notiger-->
- <constant name="struts.objectTypeDeterminer"value="tiger"/>
-
- <!--该属性指定处理MIME-typemultipart/form-data,文件上传-->
- <constant name="struts.multipart.parser"
value="cos"/>
- <constant name="struts.multipart.parser"
value="pell"/>
- <constant name="struts.multipart.parser"
value="jakarta"/>
-
- <!--指定上传文件时的临时目录,默认使用javax.servlet.context.tempdir-->
- <constant name="struts.multipart.saveDir"
value="/tmpuploadfiles"/>
-
- <!--该属性指定Struts2文件上传中整个请求内容允许的最大字节数-->
- <constant name="struts.multipart.maxSize"
value="2097152"/>
-
- <!--
- 该属性指定Struts2应用加载用户自定义的属性文件,该自定义属性文件指定的属性不会覆盖
- struts.properties文件中指定的属性。如果需要加载多个自定义属性文件,多个自定义属性文
- 件的文件名以英文逗号(,)隔开。(也就是说不要改写struts.properties!)
- -->
- <constant name="struts.custom.properties"
- value="application,org/apache/struts2/extension/custom"/>
-
- <!--指定请求url与action映射器,默认为org.apache.struts2.dispatcher.mapper.DefaultActionMapper-->
- <constant name="struts.mapper.class"
value="org.apache.struts2.dispatcher.mapper.DefaultActionMapper"/>
-
- <!--指定action的后缀,默认为action-->
- <constant name="struts.action.extension"
value="do"/>
-
- <!--被FilterDispatcher使用指定浏览器是否缓存静态内容,测试阶段设置为false,发布阶段设置为true.-->
- <constant name="struts.serve.static.browserCache
"value="true"/>
-
- <!--设置是否支持动态方法调用,true为支持,false不支持.-->
- <constant name="struts.enable.DynamicMethodInvocation"
value="true"/>
-
- <!--设置是否可以在action中使用斜线,默认为false不可以,想使用需设置为true.-->
- <constant name="struts.enable.SlashesInActionNames" value="true"/>
-
- <!--是否允许使用表达式语法,默认为true.-->
- <constant name="struts.tag.altSyntax"
value="true"/>
-
- <!--设置当struts.xml文件改动时,是否重新加载-->
- <constant name="struts.configuration.xml.reload"
value="true"/>
-
- <!--设置struts是否为开发模式,默认为false,测试阶段一般设为true.-->
- <constant name="struts.devMode"
value="true"/>
-
- <!--设置是否每次请求,都重新加载资源文件,默认值为false.-->
- <constant name="struts.i18n.reload"
value="false"/>
-
- <!--标准的UI主题,默认的UI主题为xhtml,可以为simple,xhtml或ajax-->
- <constant name="struts.ui.theme"
value="xhtml"/>
-
- <!--模板目录-->
- <constant name="struts.ui.templateDir"
value="template"/>
-
- <!--设置模板类型.可以为ftl,vm,orjsp-->
- <constant name="struts.ui.templateSuffix"
value="ftl"/>
-
- <!--定位velocity.properties文件.默认velocity.properties-->
- <constant name="struts.velocity.configfile"
value="velocity.properties"/>
-
- <!--设置velocity的context.-->
- <constant name="struts.velocity.contexts"
value="...."/>
-
- <!--定位toolbox-->
- <constant name="struts.velocity.toolboxlocation"
value="...."/>
-
- <!--指定web应用的端口-->
- <constant name="struts.url.http.port"
value="80"/>
-
- <!--指定加密端口-->
- <constant name="struts.url.https.port"
value="443"/>
-
- <!--设置生成url时,是否包含参数.值可以为:none,getorall-->
- <constant name="struts.url.includeParams"
value="get"/>
-
- <!--设置要加载的国际化资源文件,以逗号分隔.-->
- <constant name="struts.custom.i18n.resources"
value="application"/>
-
- <!--对于一些web应用服务器不能处理HttpServletRequest.getParameterMap(),
- 像WebLogic,Orion,andOC4J等,须设置成true,默认为false.-->
- <cosntantname="struts.dispatcher.parametersWorkaround"value="false"/>
-
- <!--指定freemarker管理器-->
- <constant name="struts.freemarker.manager.classname"
value="org.apache.struts2.views.freemarker.FreemarkerManager"/>
-
- <!--设置是否对freemarker的模板设置缓存,效果相当于把template拷贝到WEB_APP/templates.-->
- <cosntantname="struts.freemarker.templatesCache"value="false"/>
-
- <!--通常不需要修改此属性.-->
- <constant name="struts.freemarker.wrapper.altMap"
value="true"/>
-
- <!--指定xsltresult是否使用样式表缓存.开发阶段设为true,发布阶段设为false.-->
- <cosntantname="struts.xslt.nocache"value="false"/>
- <!--设置struts自动加载的文件列表.-->
- <constant name="struts.configuration.files"
value="struts-default.xml,struts-plugin.xml,struts.xml"/>
-
- <!--设定是否一直在最后一个slash之前的任何位置选定namespace.-->
- <constant name="struts.mapper.alwaysSelectFullNamespace"
value="false"/>
- </struts>
=======================================================
1、在struts2中,表单中提交的action,为什么一定要用xxx.action的形式呢?原因是在default.properties这个资源文件(只读)中是这么定义的。可以去修改它里面的配置。(方法是:在src目录下创建struts.properties文件,然后修改成自己需要的形式即可。),另外,为什么struts2的配置文件名一定要是struts.xml呢?其实这些定义都是在default.properties文件(只读)中配置好的。当然可以找到它,进行修改。(方法是:在src目录下创建struts.properties文件,然后修改成自己需要的形式即可。原因是)
2、如何防止表单中提交的中文,取出后显示是乱码:解决方法:
只需要在struts.xml文件的<struts></struts>标签间加入一句代码即可
<struts>
<constantname=”struts.i18n.encoding”value=”GBK”></constant>
</struts>
当然,也可以在struts.properties或web.xml中进行转码的配置。但是优先级的顺序是:web.xml>struts.properties>struts.xml
在struts.properties(位于src目录下)中配置转码的格式:
struts.i18n.encoding=GBK
在web.xml中配置转码的代码是:在<filter></filter>中增加如下代码:
<filter>
<init-param>
<param-name>struts.i18n.encoding</param-name>
<param-value>GBK</param-value>
</init-param>
</filter>
3、要测试一个action运行的时间(会在控制台输出执行时间)。只需要struts.xml文件中的<package></package>标签中加入如一代码(拦截器,具体说明与使用需要查看struts-default.xml文件),并在需要测试的action标签内部加上对它的引用即可。
<package>
<interceptors>
<interceptorname=”timer”class=”com.opensymphony.xwork2.interceptor.TimerInterceptor”>
</<interceptorname=”params”class=”om.opensymphony.xwork2.interceptor.ParametersIncerceptor”>//为获取表单的参数需要加入这一句
<interceptor>
</interceptor>
</interceptors>
</package>
下面是对上面代码的引用:
<action>
<interceptor-refname=”timer”/>
<interceptor-refname=”params”/>//引用一下获取表单参数
</action>
也就是说:如果加上了timer这个属性,就得加上params这个参数来获取表单中的参数。有点类似构造方法的原理
4、struts.xml文件中<action method=”方法名”></action>标签中的method属性,来指定该action调用method属性的值的那个方法。方法可以定义在xxxAction.java文件中。如:struts.xml中配置如下
<actionname="modify"class="com.test.action.TestMethod"method="modify">
<resultname="success">/resultmodify.jsp</result>
</action>
//表示modify这个方法存在于TestMethod.java这个类中。只要浏览器一请求modify.action,就会自动转到相应的类中并调用相应的mofidy()。当然,<action></action>标签中的name属性名是可以随意取的。只是在请求时名称要与它一致即可。
<actionname="query"class="com.test.action.TestMethod"method="query">
<resultname="success">/resultquery.jsp</result>
</action>
//与上面的功能类似
5、在action标签中用通配符映射来匹配:
* 表示0-N个字符,不包括/ 常用
** 表示0-N个字符,包括/
\ 表示转义符
比如:将上面两个action标签合并为一个action标签。如下:
<action name="*User" class="com.test.action.TestMethod" method="{1}">
<result name="success">/{1}UserSucc.jsp</result>
</action>
它可以表示任何对User进行操作的acion。都由TestMethod这个类来处理。并且method属性的值,是随着访问的变化而进行变化调用类中相应的方法。跳转到的页面也一样的规律。这种方式,要求取的方法名要有规律。
没有任何通配符的action匹配优先级最高。有通配符时,一律按顺序匹配。
|