阿錄幫幫忙—第三章—struts.xml的配置

具體配置例子請在下載的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文件了。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章