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、過濾器被再次執行
核心接口和類
根據請求的URI查找是否存在對應Action調用
ActionMapping
保存調用Action的映射信息,如namespace、name等
ActionProxy
在XWork和真正的Action之間充當代理
ActionInvocation
表示Action的執行狀態,保存攔截器、Action實例
Interceptor
可以在請求處理之前或者之後執行的Struts 2組件
Struts 2絕大多數功能通過攔截器完成
攔截器
攔截器方法在Action執行之前或者之後執行
攔截器棧
從結構上看,攔截器棧相當於多個攔截器的組合
在功能上看,攔截器棧也是攔截器
攔截器與過濾器原理很相似
1、做一些Action執行前的預處理
2、將控制交給後續攔截器或返回結果字符串
3、做一些Action執行後的處理
自帶攔截器:
負責將請求參數設置爲Action屬性
servletConfig攔截器
將源於Servlet API的各種對象注入到Action
fileUpload攔截器
對文件上傳提供支持
exception攔截器
捕獲異常,並且將異常映射到用戶自定義的錯誤頁面
validation攔截器
調用驗證框架進行數據驗證
workflow攔截器
調用Action類的validate(),執行編碼驗證
Struts 2默認攔截器棧
<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方法即可
推薦使用