經過對這些屬性的配置,能夠改變Struts 2 框架的一些默認行爲,這些配置能夠在struts.xml文件中完成,也能夠在struts.properties文件中完成。
1.<constant name="struts.i18n.encoding" value="UTF-8" />
指定Web應用的默認編碼集,至關於調用 HttpServletRequest的setCharacterEncoding方法。
2.<constant name="struts.i18n.reload" value="false"/>
該屬性設置是否每次HTTP請求到達時,系統都從新加載資源文件。該屬性默認值是false。在開發階段將該屬性設置爲true會更有利於開發, 但在產品發佈階段應將該屬性設置爲false。
3.<constant name="struts.custom.i18n.resources" value="application"/>
該屬性指定Struts 2應用所須要的國際化資源文件,若是有多份國際化資源文件,則多個資源文件的文件名以英文逗號(,)隔開。
4.<constant name="struts.action.extension" value="action" />
該屬性指定須要Struts 2處理的請求後綴,該屬性的默認值是action,即全部匹配*.action的請求都由Struts 2處理。若是用戶須要指定多個請求後綴,則多個後綴之間以英文逗號(,)隔開。
5.<constant name="struts.serve.static.browserCache " value="true" />
設置瀏覽器是否緩存靜態內容,默認值爲true(生產環境下使用),開發階段最好關閉。
6.<constant name="struts.configuration.xml.reload" value="false" />
當struts 2的配置文件修改後,系統是否自動從新加載該文件,默認值爲false(生產環境下使用),開發階段最好打開。
7.<constant name="struts.configuration.files" value="struts-default.xml,struts-plugin.xml,struts.xml"/>
該屬性指定Struts 2框架默認加載的配置文件,若是須要指定默認加載多個配置文件,則多個配置文件的文件名之間以英文逗號(,)隔開。該屬性的默認值爲struts- default.xml,struts-plugin.xml, struts.xml,看到該屬性值,讀者應該明白爲何Struts 2框架默認加載struts.xml文件了。
8.<constant name="struts.configuration" value="org.apache.struts2.config.DefaultConfiguration"/>
指定加載struts2配置文件管理器,默認爲org.apache.struts2.config.DefaultConfiguration,開發者能夠自定義配置文件管理器,該類要實現Configuration接口,能夠自動加載struts2配置文件。
8.<constant name="struts.continuations.package" value=""/>
含有Actions的完整連續的package名稱。
10.<constant name="struts.devMode" value="true" />
開發模式下使用,這樣能夠打印出更詳細的錯誤信息。
11.<constant name="struts.serve.static.browserCache" value="false"/>
該屬性設置瀏覽器是否緩存靜態內容。當應用處於開發階段時,咱們但願每次請求都得到服務器的最新響應,則可設置該屬性爲false。
12.<constant name="struts.enable.DynamicMethodInvocation" value="false"/>
該屬性設置Struts 2是否支持動態方法調用,該屬性的默認值是true。若是須要關閉動態方法調用,則可設置該屬性爲false。
13.<constant name="struts.enable.SlashesInActionNames" value="false"/>
該屬性設置Struts 2是否容許在Action名中使用斜線,該屬性的默認值是false。若是開發者但願容許在Action名中使用斜線,則可設置該屬性爲true。
14.<constant name="struts.tag.altSyntax" value="true"/>
該屬性指定是否容許在Struts 2標籤中使用表達式語法,由於一般都須要在標籤中使用表達式語法,故此屬性應該設置爲true,該屬性的默認值是true。
15.<constant name="struts.devMode" value="false"/>
該屬性設置Struts 2應用是否使用開發模式。若是設置該屬性爲true,則能夠在應用出錯時顯示更多、更友好的出錯提示。該屬性只接受true和flase兩個值,該屬性的默認值是false。一般,應用在開發階段,將該屬性設置爲true,當進入產品發佈階段後,則該屬性設置爲false。
16.<constant name="struts.ui.theme" value="xhtml"/>
該屬性指定視圖標籤默認的視圖主題,該屬性的默認值是xhtml,能夠爲simple,xhtml或ajax。
17.<constant name="struts.ui.templateDir" value="template"/>
該屬性指定視圖主題所須要模板文件的位置,該屬性的默認值是template,即默認加載template路徑下的模板文件。
18.<constant name="struts.ui.templateSuffix" value="ftl"/>
該屬性指定模板文件的後綴,該屬性的默認屬性值是ftl。該屬性還容許使用ftl、vm或jsp,分別對應FreeMarker、 Velocity和JSP模板。
19.<constant name="struts.velocity.configfile" value="velocity.properties"/>
該屬性指定Velocity框架所需的velocity.properties文件的位置。該屬性的默認值爲 velocity.properties。
20.<constant name="struts.velocity.contexts" value=""/>
該屬性指定Velocity框架的Context位置,若是該框架有多個Context,則多個Context之間以英文逗號(,)隔開。
21.<constant name="struts.velocity.toolboxlocation" value=""/>
該屬性指定Velocity框架的toolbox的位置。
22.<constant name="struts.url.http.port" value="80"/>
該屬性指定Web應用所在的監聽端口。該屬性一般沒有太大的用處,只是當Struts 2須要生成URL時(例如Url標籤),該屬性才提供Web應用的默認端口。
23.<constant name="struts.url.https.port" value="443"/>
該屬性相似於struts.url.http.port屬性的做用,區別是該屬性指定的是Web應用的加密服務端口。
24.<constant name="struts.url.includeParams" value="none|get|all"/>
該屬性指定Struts 2生成URL時是否包含請求參數。該屬性接受none、get和all三個屬性值,分別對應於不包含、僅包含GET類型請求參數和包含所有請求參數。
25.<constant name="struts.dispatcher.parametersWorkaround" value="false"/>
對於某些Java EE服務器,不支持HttpServlet Request調用getParameterMap()方法,此時能夠設置該屬性值爲true來解決該問題。該屬性的默認值是false。對於 WebLogic、Orion和OC4J服務器,一般應該設置該屬性爲true。
26.<constant name="struts.freemarker.manager.classname" value=""/>
該屬性指定Struts 2使用的FreeMarker管理器。該屬性的默認值是org.apache.struts2.views.freemarker.FreemarkerManager,這是 Struts 2內建的FreeMarker管理器。
27.<constant name="struts.freemarker.wrapper.altMap" value="true"/>
該屬性只支持true和false兩個屬性值,默認值是true。一般無需修改該屬性值。
28.<cosntant name="struts.freemarker.templatesCache" value="false" />
設置是否對freemarker的模板設置緩存,效果至關於把template拷貝到 WEB_APP/templates.
29.<constant name="struts.xslt.nocache" value="false"/>
該屬性指定XSLT Result是否使用樣式表緩存。當應用處於開發階段時,該屬性一般被設置爲true;當應用處於產品使用階段時,該屬性一般被設置爲false。
30.<constant name="struts.custom.properties" value="application,org/apache/struts2/extension/custom
"/>
指定Struts2應用加載用戶自定義的屬性文件,該自定義屬性文件指定的屬性不會覆蓋struts.properties文件中指定的屬性。若是須要加載多個自定義屬性文件,多個自定義屬性文件的文件名以英文逗號(,)隔開。(也就是說不要改寫struts.properties!)html
31.<constant name="struts.locale" value="zh_CN"/>
默認的國際化地區信息。
32.<constant name="struts.mapper.class" value="org.apache.struts2.dispatcher.mapper.DefaultActionMapper"/>
指定請求url與action映射器,默認爲org.apache.struts2.dispatcher.mapper.DefaultActionMapper
33.<cosntant name="struts.mapper.alwaysSelectFullNamespace" value="false" />
設定是否一直在最後一個slash以前的任何位置選定namespace
34.<constant name="struts.multipart.maxSize" value="2097152"/>
multipart請求信息的最大尺寸(文件上傳用,該屬性指定Struts 2文件上傳中整個請求內容容許的最大字節數)。
35.<constant name="struts.multipart.parser" value="cos"/>
該屬性指定處理 MIME-type multipart/form-data,文件上傳(cos、pell、jakarta)
專爲multipart請求信息使用的org.apache.struts2.dispatcher.multipart.MultiPartRequest解析器接口(文件上傳用)。
36.<constant name="struts.multipart.saveDir" value="/tmpuploadfiles"/>
指定上傳文件時的臨時目錄,默認使用 javax.servlet.context.tempdir。
37.<constant name="struts.objectFactory" value="spring" />
該屬性指定Struts 2中的Action由Spring容器建立。
38.<constant name="struts.objectFactory.spring.autoWire" value="name"/>
指定spring框架的裝配模式,裝配方式有: name, type, auto, and constructor (name 是默認裝配模式)
39.<constant name="struts.objectFactory.spring.useClassCache" value="true"/>
該屬性指定整合spring時,是否對bean進行緩存,值爲true or false,默認爲true。
40.<cosntant name="struts.objectTypeDeterminer" value="tiger" />
指定類型檢查,包含tiger和notigerjava