具體配置例子請在下載的stuts的apps的例子中去查找;
一、Action名稱的搜索順序介紹
例如:localhost/test/login.htm存在;
則: localhost/test/xxx01/xxx02/login.htm也是能夠訪問的;
原因:訪問地址的時候,首先搜索pachage名稱,順序=>xxx02(不存在)=>xxx01(不存在)=>test(存在);發現test存在,則pachage就有效;
然後去訪問action地址:login.htm
二、Action的各項默認值
1,class 默認值->ActionSupport
2,method 默認值->excute()
3,name 默認值->"success"
三、result視圖轉換類型(常用)
1,redirect
例如:
2,redirectAction(轉向action)
例如:
3,plainText(原樣輸出代碼)
4,chain
四、struts2常量定義
1,<constant name="struts.i18n.encoding" value="UTF-8" />
指定Web應用的默認編碼集,相當於調用HttpServletRequest的setCharacterEncoding方法
2,<constant name="struts.action.extension" value="do" />
該屬性指定需要Struts 2處理的請求後綴,該屬性的默認值是action,即所有匹配*.action的請求都由Struts 2處理。 如果用戶需要指定多個請求後綴,
則多個後綴之間 英文逗號(,)隔開。
3,<constant name="struts.serve.static.browserCache " value="false" />
設置瀏覽器是否緩存靜態內容,默認值爲true,開發階段最好false
4,<constant name="struts.configuration.xml.reload" value="true" />
當struts的配置文件修改後,系統是否自動重新加載該文件,默認值爲false,開發階段最好true
5,<constant name="struts.devMode" value="true" />
開發模式下設爲true,這樣可以打印出更詳細的錯誤信息
6,<constant name="struts.enable.DynamicMethodInvocation" value="false" />
動態方法調用,可以解決多個請求對應一個Servlet的問題,後面詳細講解,默認爲true,關閉則設爲false.
下面是其他的一些常量,使用方法和上面相同。
7,struts.serve.static.browserCache 該屬性設置瀏覽器是否緩存靜態內容。當應用處於開發階段時,我們希望每次請求都獲得服務器的最新響應,則可設置該屬性爲false。
8,struts.enable.DynamicMethodInvocation 該屬性設置Struts 2是否支持動態方法調用,該屬性的默認值是true。如果需要關閉動態方法調用,則可設置該屬性爲false。
9,struts.enable.SlashesInActionNames 該屬性設置Struts 2是否允許在Action名中使用斜線,該屬性的默認值是false。如果開發者希望允許在Action名中使用斜線,則可 設置該屬性爲true。
10,struts.tag.altSyntax 該屬性指定是否允許在Struts 2標籤中使用表達式語法,因爲通常都需要在標籤中使用表達式語法,故此屬性應該設置爲true,該屬性的默認值是true。
11,struts.devMode該屬性設置Struts 2應用是否使用開發模式。如果設置該屬性爲true,則可以在應用出錯時顯示更多、更友好的出錯提示。該屬性只接受true和flase兩個值,該屬性的默認值是false。通常,應用在開發階段,將該屬性設置爲true,當進入產品發佈階段後,則該屬性設置爲false。
12,struts.i18n.reload該屬性設置是否每次HTTP請求到達時,系統都重新加載資源文件。該屬性默認值是false。在開發階段將該屬性設置爲true會更有利於開發,但在產品發佈階段應將該屬性設置爲false。
提示 開發階段將該屬性設置了true,將可以在每次請求時都重新加載國際化資源文件,從而可以讓開發者看到實時開發效果;產品發佈階段應該將該屬性設置爲false,是爲了提供響應性能,每次請求都需要重新加載資源文件會大大降低應用的性能。
13,struts.ui.theme該屬性指定視圖標籤默認的視圖主題,該屬性的默認值是xhtml。
14,struts.ui.templateDir該屬性指定視圖主題所需要模板文件的位置,該屬性的默認值是template,即默認加載template路徑下的模板文件。
15,struts.ui.templateSuffix該屬性指定模板文件的後綴,該屬性的默認屬性值是ftl。該屬性還允許使用ftl、vm或jsp,分別對應FreeMarker、Velocity和JSP模板。
16,struts.configuration.xml.reload該屬性設置當struts.xml文件改變後,系統是否自動重新加載該文件。該屬性的默認值是false。
17,struts.velocity.configfile該屬性指定Velocity框架所需的velocity.properties文件的位置。該屬性的默認值爲velocity.properties。
18,struts.velocity.contexts該屬性指定Velocity框架的Context位置,如果該框架有多個Context,則多個Context之間以英文逗號(,)隔開。
19,struts.velocity.toolboxlocation該屬性指定Velocity框架的toolbox的位置。
20,struts.url.http.port該屬性指定Web應用所在的監聽端口。該屬性通常沒有太大的用戶,只是當Struts 2需要生成URL時(例如Url標籤),該屬性才提供Web應用的默認端口。
21,struts.url.https.port該屬性類似於struts.url.http.port屬性的作用,區別是該屬性指定的是Web應用的加密服務端口。
22,struts.url.includeParams該屬性指定Struts 2生成URL時是否包含請求參數。該屬性接受none、get和all三個屬性值,分別對應於不包含、僅包含GET類型請求參數和包含全部請求參數。
23,struts.custom.i18n.resources該屬性指定Struts 2應用所需要的國際化資源文件,如果有多份國際化資源文件,則多個資源文件的文件名以英文逗號(,)隔開。
24,struts.dispatcher.parametersWorkaround 對於某些Java EE服務器,不支持HttpServlet Request調用getParameterMap()方法,此時可以設置該屬性值爲true來解決該問題。該屬性的默認值是false。對於WebLogic、Orion和OC4J服務器,通常應該設置該屬性爲true。
25,struts.freemarker.manager.classname 該屬性指定Struts 2使用的FreeMarker管理器。該屬性的默認值是org.apache.struts2.views.freemarker.FreemarkerManager,這是Struts 2內建的FreeMarker管理器。
26,struts.freemarker.wrapper.altMap該屬性只支持true和false兩個屬性值,默認值是true。通常無需修改該屬性值。
27,struts.xslt.nocache 該屬性指定XSLT Result是否使用樣式表緩存。當應用處於開發階段時,該屬性通常被設置爲true;當應用處於產品使用階段時,該屬性通常被設置爲 false。
28,struts.configuration.files 該屬性指定Struts 2框架默認加載的配置文件,如果需要指定默認加載多個配置文件,則多個配置文件的文件名之間以英文逗號(,)隔開。該屬性的默認值爲struts-default.xml,struts-plugin.xml,struts.xml,看到該屬性值,讀者應該明白爲什麼Struts 2框架默認加載struts.xml文件了。