一、Struts2基本流程
大致上,Struts2框架由三部分組成:核心控制器FilterDispatcher、業務控制器和用戶實現的業務邏輯組件。在這三部分裏,Struts2框架提供了核心控制器,
而用戶需要實現業務控制器和業務邏輯組件。
1、核心控制器(FilterDispatcher)
FilterDispatcher是Struts2框架的核心控制器,該控制器作爲一個Filter運行在web框架中,它負責攔截所有的用戶請求,當用戶請求到達時,該Filter會自
動過濾用戶請求。如果用戶請求以action結尾,該請求被轉入struts2框架處理。
當Struts2獲得*.action的請求後,會根據*.action的*部分判斷調用哪個業務邏輯組件,例如user.action請求,Struts2會調用Action爲user的業務邏輯來
處理該請求,Struts2的Action定義在struts.xml文件中。
2、業務控制器
業務控制器實際上就是用戶實現Action類的實例,在此類中繼承ActionSupport這個類,一般要重寫它的execute方法。此方法返回一個字符串,根據處理結果的
不同,返回的字符串也不同,每個字符串對應着一個相應的返回視圖。
我們開發出Action類之後還要在struts.xml文件中配置這個Action,有如下三部分需要定義:
(1)配置Action的name值,與客戶端請求的Url對應
(2)配置Action組件的實現類,即class屬性
(3)配置Action所包含的邏輯視圖與物理資源之間的關係。即result標籤的屬性。
3、Struts2模型組件
Struts2的業務控制器不會對用戶的請求進行處理,用戶的請求一般最終由模型組件來處理,業務控制器只是負責中間調度的。
就比如平時做的項目中一般是由action層調用service層的方法對用戶請求進行處理,srrvice層下面還可能隱含着Dao層。
4、Struts2的基本流程
Struts2的大致執行流程有如下幾步:
(1)用戶發起請求(.action表示一個Action請求)
(2)Struts2的FilterDispatcher攔截到用戶發起的請求,判斷這個請求是否是Action請求,如果是Action請求,那麼交給對應的Action進行處理,在這個
過程中需要一個輔助對象:Action映射器(ActionMapper)
(3)交給對應的Action處理之後,根據struts.xml中對此Action的配置信息,首先執行攔截此Action的所有攔截器,然後再執行請求的Action對象。
(4)Action執行完畢之後需要返回一個結果(此結果用字符串表示),核心控制器根據此返回結果從配置文件中找到真正的路徑,然後將請求轉發給相應的視
圖,由視圖向客戶端做出相應的響應。
二、Struts2的基本配置
配置3個文件:web.xml struts.xml struts.properties
1、web.xml
任何MVC框架都需要與web應用整合,這就不得不借助web.xml這個文件,只有配置在web.xml中的Servlet纔會被應用加載。
通常,所有的MVC框架都需要在web.xml中加載一個核心控制器,對於Struts2框架而言,需要加載FilterDispatcher,web應用只需要負責加載
FilterDispatcher,FilterDispatcher就會自動加載Struts2框架。
在web.xml中配置FilterDispatcher的代碼片段如下:
<!-- 配置Struts2的核心Filter -->
<filter>
<!-- 配置Struts2核心Filter的名字 -->
<filter-name>struts2</filter-name>
<!-- 配置Struts2核心Filter的實現類 -->
<filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>
</filter>
<!-- 配置Filter攔截的url,通過此配置讓Filter攔截所有的用戶請求 -->
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
當然,配置這個Filter的時候也可以指定一些初始化參數或者常量(比如struts2的編碼),平時我沒怎麼用到在這塊加參數,所以沒寫,但是要知道這塊是可以
加初始化參數的。
2、配置struts.xml
Struts2框架的核心配置文件就是struts.xml,該文件主要負責管理struts2框架的業務控制器,也就是管理Action。
在默認情況下,Struts2框架將自動加載放到/WEB-INF/classes路徑下的struts.xml文件(所以我們在eclipse中要將struts.xml放到項目的src目錄下)。
在大部分應用中,隨着應用規模的增加,系統中的Action數量也在增多,造成struts,xml文件臃腫,所以我們在開發的時候要將Action分類配置到不同的xml
文件中,然後在struts.xml文件中包含其他的配置文件,例如,<include file="struts_util.xml"/>。這樣可以提高struts.xml文件的可讀性。
看一個struts.xml文件的結構,就是一個示範文件:
<?xml version = "1.0" encoding = "UTF-8"?>
<!--下面是Struts2配置文件的DTD信息 -->
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<!--struts是struts2配置文件的跟元素 -->
<struts>
<!--下面的元素可以出現0次,也可以出現無限多次 -->
<constant name="" value="" />
<!--下面的元素可以出現0次,也可以出現無限多次 -->
<bean type="" name="" class="" scope="" static="" optional="" />
<!--下面的元素可以出現0次,也可以出現無限多次 -->
<include file="" />
<!--package元素是struts配置文件的核心,該元素可以出現0次,或者是無限多次 -->
<package name="必填的包名" extends="" namespace="" abstract="" externalReferenceResovler>
<!--以下該元素可以出現,也可以不出現,最多出現一次 -->
<result-types>
<!--以下該元素必須出現,可以出現無數多次 -->
<result-type name="" class="" default="true\false">
<!--下面的元素可以出現0次,也可以出現無限多次 -->
<param name="參數名">參數值 </param>
</result-type>
</result-types>
<!--以下的該元素可以出現,也可以不出現,但最多出現1次 -->
<interceptors>
<!--interceptors元素的子元素interceptor元素和interceptor-stack至少出現其中之一,也可以兩者都出現 -->
<!--下面的元素可以出現0次,也可以出現無限多次 -->
<interceptor name="" class="">
<!--下面的元素可以出現0次,也可以出現無限多次 -->
<param name="參數名">參數值 </param>
</interceptor>
<!--下面的元素可以出現0次,也可以出現無限多次 -->
<interceptor-stack name="">
<!-- 下面的元素必須出現,可以出現無數多次 -->
<interceptor-ref name="">
<!-- 下面的元素可以出現0次,也可以出現無限多次 -->
<param name="參數名">參數值</param>
</interceptor-ref>
</interceptor-stack>
</interceptors>
<!-- 下面的元素可以出現0次,也可以出現無限多次 -->
<default-interceptor-ref name="">
<!-- 下面的元素可以出現0次,也可以出現無限多次 -->
<param name="參數名">參數值</param>
</default-interceptor-ref>
<!-- 下面的元素可以出現0次,也可以出現無限多次 -->
<default-action-ref name="">
<!-- 下面的元素可以出現0次,也可以出現無限多次 -->
<param name="參數名">參數值</param>
</default-action-ref>
<!-- 下面的元素可以出現0次,也可以出現無限多次 -->
<global-results>
<!-- 該元素必須出現,可以出現無限多次 -->
<result name="" type="">
<!-- 該字符串內容可以出現0次或者多次 -->
映射資源
<!-- 下面的元素可以出現0次,也可以出現無限多次 -->
<param name="參數名">參數值</param>
</result>
</global-results>
<!-- 下面的元素可以出現0次,也可以出現多次 -->
<global-exception-mappings>
<!-- 該元素必須出現,可以出現多次 -->
<exception-mapping name="" exception="" result="">
異常處理資源
<!-- 下面的元素可以出現0次,也可以出現無限多次 -->
<param name="參數名">參數值</param>
</exception-mapping>
</global-exception-mappings>
<action name="" class="" method="" convertor="">
<!-- 下面的元素可以出現0次,也可以出現無限多次 -->
<param name="參數名">參數值</param>
<!-- 下面的元素可以出現0次,也可以出現無限多次 -->
<result name="" type="">
映射資源
<!-- 下面的元素可以出現0次,也可以出現無限多次 -->
<param name="參數名">參數值</param>
</result>
<!-- 下面的元素可以出現0次,也可以出現無限多次 -->
<interceptor-ref name="">
<!-- 下面的元素可以出現0次,也可以出現無限多次 -->
<param name="參數名">參數值</param>
</interceptor-ref>
<!-- 下面的元素可以出現0次,也可以出現無限多次 -->
<exception-mapping name="" exception="" result="">
異常處理資源
<!-- 下面的元素可以出現0次,也可以出現無限多次 -->
<param name="參數名">參數值</param>
</exception-mapping>
</action>
</package>
</struts>
上面配置文件中的內容較多,我們可以從中瞭解到struts.xml文件的一個完整結構,但是各個配置元素的意義不一定都能深入瞭解,在這裏不多牽扯細節的地
方,後面文章會逐步的去探索每一個配置元素的意義。
3、配置struts.properties
Struts2框架由兩大核心配置文件,其中struts.xml文件主要負責管理應用中的Action映射,以及該Action包含的Result定義等,除此之外,Struts2框架還包
含一個struts.properties的配置文件,該文件定義了Struts2框架的大量屬性,開發者可以通過改變這些屬性來滿足應用需求。
struts.properties文件中包含大量的key-value對應,每個key就是一個Struts2屬性,每個value就是一個Struts2屬性值。
struts.properties文件通常放在WEB-INF/classes目錄下。
可配置屬性及說明如下:
struts.configuration:該屬性指定加載Struts 2配置文件的配置文件管理器。該屬性的默認值是org.apache.Struts2.config.DefaultConfiguration,
這是Struts 2默認的配 置文件管理器。如果需要實現自己的配置管理器,開發者則可以實現一個實現Configuration接口的類,
該類可以自己加載Struts 2配置文件。
struts.locale:指定Web應用的默認Locale。
struts.i18n.encoding:指定Web應用的默認編碼集。該屬性對於處理中文請求參數非常有用,對於獲取中文請求參數值,應該將該屬性值設置爲GBK或
者GB2312。提示 當設置該參數爲GBK時,相當於調用HttpServletRequest的setCharacterEncoding方法。
struts.objectFactory:指定Struts 2默認的ObjectFactoryBean,該屬性默認值是spring。
struts.objectFactory.spring.autoWire:指定Spring框架的自動裝配模式,該屬性的默認值是name,即默認根據Bean的name屬性自動裝配。
struts.objectFactory.spring.useClassCache:該屬性指定整合Spring框架時,是否緩存Bean實例,該屬性只允許使用true和false兩個屬性值,
它的默認值是true。通常不建議修改該屬性值。
struts.objectTypeDeterminer:該屬性指定Struts 2的類型檢測機制,通常支持tiger和notiger兩個屬性值。
struts.multipart.parser:該屬性指定處理multipart/form-data的MIME類型(文件上傳)請求的框架,該屬性支持cos、pell和jakarta等屬性值,
即分別對應使用cos的文件上傳框架、pell上傳及common-fileupload文件上傳框架。該屬性的默認值爲jakarta。注意 如果需要使用cos或者pell的文件
上傳方式,則應該將對應的JAR文件複製到Web應用中。例如,使用cos上傳方式,則需要自己下載cos框架的JAR文件,並將該文件放在WEB-INF/lib路徑下。
struts.multipart.saveDir:該屬性指定上傳文件的臨時保存路徑,該屬性的默認值是javax.servlet.context.tempdir。
struts.multipart.maxSize:該屬性指定Struts 2文件上傳中整個請求內容允許的最大字節數。
struts.custom.properties:該屬性指定Struts 2應用加載用戶自定義的屬性文件,該自定義屬性文件指定的屬性不會覆蓋struts.properties文件
中指定的屬性。如果需要加載多個自定義屬性文件,多個自定義屬性文件的文件名以英文逗號(,)隔開。
struts.mapper.class:指定將HTTP請求映射到指定Action的映射器,Struts 2提供了默認的映射
器:org.apache.struts2.dispatcher.mapper.DefaultActionMapper。默認映射器根據請求的前綴與Action的name屬性完成映射。
struts.action.extension:該屬性指定需要Struts 2處理的請求後綴,該屬性的默認值是action,即所有匹配*.action的請求都由Struts 2處理。
如果用戶需要指定多個請求後綴,則多個後綴之間以英文逗號(,)隔開。
struts.serve.static:該屬性設置是否通過JAR文件提供靜態內容服務,該屬性只支持true和false屬性值,該屬性的默認屬性值是true。
struts.serve.static.browserCache:該屬性設置瀏覽器是否緩存靜態內容。當應用處於開發階段時,我們希望每次請求都獲得服務器的最新響應,則可設置
該屬性爲false。
struts.enable.DynamicMethodInvocation:該屬性設置Struts 2是否支持動態方法調用,該屬性的默認值是true。如果需要關閉動態方法調用,則可設置該
屬性爲false。
struts.enable.SlashesInActionNames:該屬性設置Struts 2是否允許在Action名中使用斜線,該屬性的默認值是false。如果開發者希望允許在Action名中
使用斜線,則可設置該屬性爲true。
struts.tag.altSyntax:該屬性指定是否允許在Struts 2標籤中使用表達式語法,因爲通常都需要在標籤中使用表達式語法,故此屬性應該設置爲true,該屬
性的默認值是true。
struts.devMode:該屬性設置Struts 2應用是否使用開發模式。如果設置該屬性爲true,則可以在應用出錯時顯示更多、更友好的出錯提示。該屬性只接受true
和flase兩個值,該屬性的默認值是false。通常,應用在開發階段,將該屬性設置爲true,當進入產品發佈階段後,則該屬性設置爲false。
struts.i18n.reload:該屬性設置是否每次HTTP請求到達時,系統都重新加載資源文件。該屬性默認值是false。在開發階段將該屬性設置爲true會更有利於開
發,但在產品發佈階段應將該屬性設置爲false。提示 開發階段將該屬性設置了true,將可以在每次請求時都重新加載國際化資源文件,從而可以讓開發者看到
實時開發效果;產品發佈階段應該將該屬性設置爲false,是爲了提供響應性能,每次請求都需要重新加載資源文件會大大降低應用的性能。
struts.ui.theme:該屬性指定視圖標籤默認的視圖主題,該屬性的默認值是xhtml。
struts.ui.templateDir:該屬性指定視圖主題所需要模板文件的位置,該屬性的默認值是template,即默認加載template路徑下的模板文件。
struts.ui.templateSuffix:該屬性指定模板文件的後綴,該屬性的默認屬性值是ftl。該屬性還允許使用ftl、vm或jsp,分別對應FreeMarker、Velocity和
JSP模板。
struts.configuration.xml.reload:該屬性設置當struts.xml文件改變後,系統是否自動重新加載該文件。該屬性的默認值是false。
struts.velocity.configfile:該屬性指定Velocity框架所需的velocity.properties文件的位置。該屬性的默認值爲velocity.properties。
struts.velocity.contexts:該屬性指定Velocity框架的Context位置,如果該框架有多個Context,則多個Context之間以英文逗號(,)隔開。
struts.velocity.toolboxlocation:該屬性指定Velocity框架的toolbox的位置。
struts.url.http.port:該屬性指定Web應用所在的監聽端口。該屬性通常沒有太大的用戶,只是當Struts 2需要生成URL時(例如Url標籤),該屬性才提供
Web應用的默認端口。
struts.url.https.port:該屬性類似於struts.url.http.port屬性的作用,區別是該屬性指定的是Web應用的加密服務端口。
struts.url.includeParams:該屬性指定Struts 2生成URL時是否包含請求參數。該屬性接受none、get和all三個屬性值,分別對應於不包含、僅包含GET類型
請求參數和包含全部請求參數。
struts.custom.i18n.resources:該屬性指定Struts 2應用所需要的國際化資源文件,如果有多份國際化資源文件,則多個資源文件的文件名以英文逗號(,)
隔開。
struts.dispatcher.parametersWorkaround:對於某些Java EE服務器,不支持HttpServletRequest調用getParameterMap()方法,此時可以設置該屬性值
爲true來解決該問題。該屬性的默認值是false。對於WebLogic、Orion和OC4J服務器,通常應該設置該屬性爲true。
struts.freemarker.manager.classname:該屬性指定Struts 2使用的FreeMarker管理器。該屬性的默認
值org.apache.struts2.views.freemarker.FreemarkerManager,這是Struts 2內建的FreeMarker管理器。
struts.freemarker.wrapper.altMap:該屬性只支持true和false兩個屬性值,默認值是true。通常無需修改該屬性值。
struts.xslt.nocache:該屬性指定XSLT Result是否使用樣式表緩存。當應用處於開發階段時,該屬性通常被設置爲true;當應用處於產品使用階段時,該屬
性通常被設置爲false。
struts.configuration.files:該屬性指定Struts 2框架默認加載的配置文件,如果需要指定默認加載多個配置文件,則多個配置文件的文件名之間以英文逗
號(,)隔開。該屬性的默認值爲struts-default.xml,struts-plugin.xml,struts.xml,看到該屬性值,讀者應該明白爲什麼Struts2框架默認加
載struts.xml文件了。
有時候開發者不喜歡額外的struts.properties文件,Struts2允許使用struts.xml文件管理這些屬性,在struts.xml文件中通過配置constant元素一樣配置
這些屬性。