struts2.0的工做原理


struts2並非一個陌生的web框架,它是以Webwork的設計思想爲核心,吸取struts1的優勢,能夠說web

struts2是struts1和Webwork結合的產物。 tomcat

struts2 的工做原理圖:app

一個請求在Struts2框架中的處理分爲如下幾個步驟:框架

1.客戶端發出一個指向servlet容器的請求(tomcat);ide

2.這個請求會通過圖中的幾個過濾器,最後會到達FilterDispatcher過濾器。spa

3.過濾器FilterDispatcher是struts2框架的心臟,在處理用戶請求時,它和請求一塊兒相互配合訪問struts2設計

  的底層框架結構。在web容器啓動時,struts2框架會自動加載配置文件裏相關參數,並轉換成相應的類。代理

  如:ConfigurationManager、ActionMapper和ObjectFactory。ConfigurationManager 存有配置文件的一xml

  些基本信息,ActionMapper存有action的配置信息。在請求過程當中全部的對象(Action,Results,對象

  Interceptors,等)都是經過ObjectFactory來建立的。過濾器會經過詢問ActionMapper類來查找請求中

  須要用到的Action。

4.若是找到須要調用的Action,過濾器會把請求的處理交給ActionProxy。ActionProxy爲Action的代理對象

  。ActionProxy經過ConfigurationManager詢問框架的配置文件,找到須要調用的Action類。

5.ActionProxy建立一個ActionInvocation的實例。ActionInvocation在ActionProxy層之下,它表示了

  Action的執行狀態,或者說它控制的Action的執行步驟。它持有Action實例和全部的Interceptor。 

6.ActionInvocation實例使用命名模式來調用,1. ActionInvocation初始化時,根據配置,加載Action相

  關的全部Interceptor。2. 經過ActionInvocation.invoke方法調用Action實現時,執行Interceptor。在

  調用Action的過程先後,涉及到相關攔截器(intercepetor)的調用。

7. 一旦Action執行完畢,ActionInvocation負責根據struts.xml中的配置找到對應的返回結果。返回結果

  一般是(但不老是,也多是另外的一個Action鏈)一個須要被表示的JSP或者FreeMarker的模版。在表

  示的過程當中可使用Struts2 框架中繼承的標籤。

0dd7912397dda1441af5ecf6b2b7d0a20df486f2



===============================================================================

===============================================================================

流程 
一、客戶端發送請求 (客戶端初始化一個指向Servlet容器(如Tomcat)的請求)
二、請求通過一系列(如ActionContextCleanUp、SiteMesh等),ActionContextCleanUp-->FilterDispatcher 
三、FilterDispatcher經過ActionMapper來決定這個Request須要調用哪一個Action 
四、若是ActionMapper決定調用某個Action,FilterDispatcher把請求的處理交給ActionProxy,
五、ActionProxy經過ConfigurationManager詢問Struts配置文件(Struts.xml),找到須要調用的Action類。
六、ActionProxy建立一個ActionInvocation的實例 
七、ActionInvocation調用真正的Action,固然這涉及到相關攔截器的調用(interceptor) 
八、Action執行完畢,ActionInvocation建立Result並返回,返回結果前要作些動做也是能夠的
相關文章
相關標籤/搜索