struts2的基本流程

1.Struts 2的基本流程 

  Struts 2框架由3個部分組成:核心控制器FilterDispatcher、業務控制器和用戶實現的業務邏輯組件。在這3個部分裏,Struts 2框架提供了核心控制器FilterDispatcher,而用戶需要實現業務控制器和業務邏輯組件。 

2.核心控制器:FilterDispatcher 

  FilterDispatcher是Struts 2框架的核心控制器,該控制器作爲一個Filter運行在Web應用中,它負責攔截所有的用戶請求,當用戶請求到達時,該Filter會過濾用戶請求。如果用戶請求以action結尾,該請求將被轉入Struts 2框架處理。 

 

Struts 2框架獲得了*.action請求後,將根據*.action請求的前面部分決定調用哪個業務邏輯組件,例如,對於login.action請求,Struts 2調用名爲login的Action來處理該請求。 

 

Struts 2應用中的Action都被定義在struts.xml文件中,在該文件中定義Action時,定義了該Action的name屬性和class屬性,其中name屬性決定了該Action處理哪個用戶請求,而class屬性決定了該Action的實現類。 

 

Struts 2用於處理用戶請求的Action實例,並不是用戶實現的業務控制器,而是Action代理——因爲用戶實現的業務控制器並沒有與Servlet API耦合,顯然無法處理用戶請求。而Struts 2框架提供了系列攔截器,該系列攔截器負責將HttpServletRequest請求中的請求參數解析出來,傳入到Action中,並回調Action 的execute方法來處理用戶請求。 

 

顯然,上面的處理過程是典型的AOP(面向切面編程)處理方式。圖3.19顯示了這種處理模型。 

 

 

 

圖3.19  Struts 2的攔截器和Action 

 

從圖3.19中可以看出,用戶實現的Action類僅僅是Struts 2的Action代理的代理目標。用戶實現的業務控制器(Action)則包含了對用戶請求的處理。用戶的請求數據包含在 HttpServletRequest對象裏,而用戶的Action類無需訪問HttpServletRequest對象。攔截器負責將 HttpServletRequest裏的請求數據解析出來,並傳給業務邏輯組件Action實例。 

3.業務控制器 

  正如從圖3.19所看到的,業務控制器組件就是用戶實現Action類的實例,Action類裏通常包含了一個execute方法,該方法返回一個字符串——該字符串就是一個邏輯視圖名,當業務控制器處理完用戶請求後,根據處理結果不同,execute方法返回不同字符串   ——每個字符串對應一個視圖名。 

 

程序員開發出系統所需要的業務控制器後,還需要配置Struts 2的Action,即需要配置Action的如下三個部分定義: 

 

—  Action所處理的URL。 

 

—  Action組件所對應的實現類。 

 

—  Action裏包含的邏輯視圖和物理資源之間的對應關係。 

 

每個Action都要處理一個用戶請求,而用戶請求總是包含了指定URL。當Filter Dispatcher攔截到用戶請求後,根據請求的URL和Action處理URL之間的對應關係來處理轉發。 

4.Struts 2的模型組件 

  實際上,模型組件已經超出了MVC框架的覆蓋範圍。對於Struts 2框架而言,通常沒有爲模型組件的實現提供太多的幫助。 

 

文本框: 圖3.20 控制器調用模型組件Java EE應用裏的模型組件,通常指系統的業務邏輯組件。而隱藏在系統的業務邏輯組件下面的,可能還包含了DAO、領域對象等組件。 

 

通常,MVC框架裏的業務控制器會調用模型組件的方法來處理用戶請求。也就是說,業務邏輯控制器不會對用戶請求進行任何實際處理,用戶請求最終由模型組件負責處理。業務控制器只是中間負責調度的調度器,這也是稱Action爲控制器的原因。 

 

 

 

圖3.20顯示了這種處理流程。 

 

提示  在圖3.20中看到Action調用業務邏輯組件的方法。當控制器需要獲得業務邏輯組件實例時,通常並不會直接獲取業務邏輯組件實例,而是通過工廠模式來獲得業務邏輯組件的實例;或者利用其他IoC容器(如Spring容器)來管理業務邏輯組件的實例。 

5.Struts 2的視圖組件 

  Struts 2已經改變了Struts 1只能使用JSP作爲視圖技術的現狀,Struts 2允許使用其他的模板技術,如FreeMarker、Velocity作爲視圖技術。 

 

當Struts 2的控制器返回邏輯視圖名時,邏輯視圖並未與任何的視圖技術關聯,僅僅是返回一個字符串,該字符串作爲邏輯視圖名。 

 

當我們在struts.xml文件中配置 Action時,不僅需要指定Action的name屬性和class屬性,還要爲Action元素指定系列result子元素,每個result子元素定義一個邏輯視圖和物理視圖之間的映射。前面所介紹的應用都使用了JSP技術作爲視圖,故配置result子元素時沒有指定type屬性,默認使用JSP 作爲視圖資源。 

 

如果需要在Struts 2中使用其他視圖技術,則可以在配置result子元素時,指定相應的type屬性即可。例如,如果需要使用FreeMarker,則爲result指定值爲freemarker的type屬性;如果想使用Velocity模板技術作爲視圖資源,則爲result指定值爲velocity的type屬性…… 

6.Struts 2的運行流程 

  經過上面介紹,我們發現Struts 2框架的運行流程非常類似於WebWork框架的流程。 

 

提示  在Struts 2的官方站點,我們可以找到如下說法:Essentially,Struts 2.0 is the technical equivalent of WebWork 2.3。Aside from the package and property renaming,it isn't much different than,say,migrating from WebWork 2.1 to 2.2——意思是說:Struts 2.0技術等同於WebWork 2.3框架,除了包和屬性被改名外。從WebWork 2.2遷移到Struts 2不會比從WebWork 2.1遷移到WebWork 2.2更復雜。 

 

這裏我們可以看到,Struts 2其實就是WebWork 2.2的升級版,這也就不難理解:爲什麼WebWork和Struts 2如此相似! 

 

因此,Struts 2的運行流程與WebWork的運行流程完全相同,讀者可以參看圖1.8來了解Struts 2的運行流程。

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