隨筆 - 63  文章 - 0  trackbacks - 0
          <2009年4月>
          2930311234
          567891011
          12131415161718
          19202122232425
          262728293012
          3456789

          常用鏈接

          留言簿(2)

          隨筆分類

          隨筆檔案

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          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的運行流程。
          posted on 2009-04-15 14:03 lanxin1020 閱讀(1443) 評論(0)  編輯  收藏 所屬分類: struts2
          主站蜘蛛池模板: 营山县| 清徐县| 安宁市| 洛阳市| 柯坪县| 石家庄市| 遂宁市| 南木林县| 张家界市| 库尔勒市| 会宁县| 定西市| 福鼎市| 辽宁省| 买车| 渝北区| 阿尔山市| 乐至县| 和龙市| 图木舒克市| 凌云县| 和顺县| 望城县| 紫阳县| 龙泉市| 日照市| 花莲县| 桦川县| 驻马店市| 乃东县| 碌曲县| 香格里拉县| 涿州市| 泾源县| 梁河县| 仪征市| 青冈县| 秦安县| 潜江市| 东城区| 高清|