struts2執行流程與攔截器介紹

struts2執行流程介紹

1、客戶端向Servlet容器(如Tomcat)提交一個請求



2、請求經過一系列過濾器(如ActionContextCleanUp過濾器等)


3、核心控制器被調用,詢問ActionMapper來決定請求是否需要調用某個Action


4、如果ActionMapper決定需要調用某個Action,核心控制器把控制權委派給ActionProxy (備註:JSP請求無需調用Action)


5、ActionProxy通過Configuration Manager詢問框架的配置文件(struts.xml),找到需調用的Action類


6、ActionProxy創建一個ActionInvocation的實例


7、 ActionInvocation負責調用Action,在此之前會依次調用所有配置的攔截器


8、Action執行完畢,ActionInvocation負責根據結果碼字符串在struts.xml的配置中找到對應的返回結果


9、攔截器被再次執行


10、過濾器被再次執行


核心接口和類

ActionMapper 
根據請求的URI查找是否存在對應Action調用
ActionMapping 
保存調用Action的映射信息,如namespace、name等
ActionProxy 
在XWork和真正的Action之間充當代理 
ActionInvocation 
表示Action的執行狀態,保存攔截器、Action實例 
Interceptor 
可以在請求處理之前或者之後執行的Struts 2組件
Struts 2絕大多數功能通過攔截器完成


攔截器

Struts 2大多數核心功能是通過攔截器實現的,每個攔截器完成某項功能 


攔截器方法在Action執行之前或者之後執行


攔截器棧
從結構上看,攔截器棧相當於多個攔截器的組合
在功能上看,攔截器棧也是攔截器 
攔截器與過濾器原理很相似

攔截器的執行過程是一個遞歸的過程 :


三階段執行週期:
1、做一些Action執行前的預處理
2、將控制交給後續攔截器或返回結果字符串
3、做一些Action執行後的處理


自帶攔截器:

Params攔截器 
負責將請求參數設置爲Action屬性
servletConfig攔截器 
將源於Servlet API的各種對象注入到Action
 fileUpload攔截器
對文件上傳提供支持
exception攔截器
捕獲異常,並且將異常映射到用戶自定義的錯誤頁面
validation攔截器 
調用驗證框架進行數據驗證 
workflow攔截器
調用Action類的validate(),執行編碼驗證


Struts 2默認攔截器棧 


struts-default.xml中定義一個defaultStack攔截器棧,並將其指定爲默認攔截器
<default-interceptor-ref name="defaultStack"/>
defaultStack提供了所有核心的Struts 2功能,滿足絕大多數應用程序的需要
只要在定義包的過程中繼承struts-default包,那麼defaultStack將是默認的攔截器
在struts-default.xml中默認的攔截器棧中包含如下攔截器

自定義攔截器示例:
public class MyTimerInterceptor extends AbstractInterceptor{	
	public String intercept(ActionInvocation invocation) 
						throws Exception {
		//預處理工作
		long startTime = System.currentTimeMillis();
              //執行後續攔截器或Action
		String result = invocation.invoke();
              //後續處理工作
	       long execTime = System.currentTimeMillis() - startTime;
             System.out.println("The interval time is "+execTime+" ms");
		//返回結果字符串
              return result;
	}
}
</pre><pre name="code" class="java">

配置攔截器:

<package name="packName" extends="struts-default" namespace="/manage">
	<interceptors>
		<!-- 定義攔截器 -->
		<interceptor name="interceptorName" class="interceptorClass" />
		<!-- 定義攔截器棧 -->
		<interceptor-stack name="interceptorStackName">
			<!--指定引用的攔截器-->
			<interceptor-ref name="interceptorName|interceptorStackName" />
		</interceptor-stack>
	</interceptors>
	<!--定義默認的攔截器引用-->
	<default-interceptor-ref name="interceptorName|interceptorStackName" />
	<action name="actionName" class="actionClass">
	  <!—爲Action指定攔截器引用-->
		<interceptor-ref name="interceptorName|interceptorStackName" />
		<!--省略其他配置-->
	</action>
</package>
實現Interceptor接口
void init():初始化攔截器所需資源
void destroy():釋放在init()中分配的資源
String intercept(ActionInvocation ai) throws Exception
實現攔截器功能
利用ActionInvocation參數獲取Action狀態
返回結果碼(result)字符串


繼承AbstractInterceptor類 
提供了init()和destroy()方法的空實現
只需要實現intercept方法即可
推薦使用

發佈了56 篇原創文章 · 獲贊 22 · 訪問量 7萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章