Struts2教程8:攔截器概述
本文為原創,如需轉載,請註明作者和出處,謝謝!
Struts2的攔截器和Servlet過濾器類似。在執行Action的execute方法之前,Struts2會首先執行在struts.xml中引用的攔截器,在執行完攔截器後,最後會執行Action的execute方法。
Struts2攔截器類必須從com.opensymphony.xwork2.interceptor.Interceptor介面繼承,在Intercepter介面中有如下三個方法需要實現:
void destroy();
void init();
String intercept(ActionInvocation invocation) throws Exception;
其中intercept方法是攔截器的核心方法,所有安裝的攔截器都會呼叫之個方法。在Struts2中已經在struts-default.xml中預定義了一些自帶的攔截器,如timer、params等。如果在標籤中繼承struts-default,則當前package就會自動擁有struts-default.xml中的所有配置。程式碼如下:
...
在struts-default.xml中有一個預設的引用,在預設情況下(也就是中未引用攔截器時)會自動引用一些攔截器。這個預設的攔截器引用如下:
dojo..*
input,back,cancel,browse
input,back,cancel,browse
上面在defaultStack中引用的攔截器都可以在中不經過引用就可以使用(如果在中引用了任何攔截器後,要使用在defaultStack中定義的攔截器,也需要在中重新引用,在後面將詳細講解)。
下面我們來看幾個簡單的攔截器的使用方法。
一、記錄攔截器和execute方法的執行時間(timer)
timer是Struts2中最簡單的攔截器,這個攔截器對應的類是com.opensymphony.xwork2.interceptor.TimerInterceptor。它的功能是記錄execute方法和其他攔截器(在timer後面定義的攔截器)的intercept方法執行的時間總和。如下面的配置程式碼所示:
由於在timer後面沒有其他的攔截器定義,因此,timer只能記錄execute方法的執行時間,在訪問first動作時,會在控制檯輸出類似下面的一條資訊:
資訊: Executed action [/test/first!execute] took 16 ms.
在使用timer攔截器時,需要commons-logging.jar的支援。將logger引用放到timer的後面,就可以記錄logger攔截器的intercept方法和Action的execute方法的執行時間總和,程式碼如下:
大家可以使用如下的Action類來測試一下timer攔截器:
package action;
import com.opensymphony.xwork2.ActionSupport;
public class FirstAction extends ActionSupport
{
public String execute() throws Exception
{
Thread.sleep(1000); // 延遲1秒
return null;
}
}
如果只記錄execute方法的執行時間,一般會輸出如下的資訊:
資訊: Executed action [/test/first!execute] took 1000 ms.
二、通過請求呼叫Action的setter方法(params)
當客戶端的一個form向服務端提交請求時,如有一個textfield,程式碼如下:
在提交後,Struts2將會自動呼叫first動作類中的setName方法,並將name文字框中的值通過setName方法的引數傳入。實際上,這個操作是由params攔截器完成的,params對應的類是com.opensymphony.xwork2.interceptor.ParametersInterceptor。由於params已經在defaultStack中定義,因此,在未引用攔截器的中是會自動引用params的,如下面的配置程式碼,在訪問first動作時,Struts2是會自動執行相應的setter方法的。
... ...
但如果在中引用了其他的攔截器,就必須再次引用params攔截器,Struts2才能呼叫相應的setter方法。如下面的配置程式碼所示:
三、通過配置引數呼叫Action的setter方法(static-params)
通過使用標籤,也可以呼叫Action類的相應的setter方法,如下面的配置程式碼所示:
比爾
如果first動作使用上面的配置,在訪問first動作時,Struts2會自動呼叫setWho方法將“比爾”作為引數值傳入setWho方法。
四、使用攔截器棧
為了能在多個動作中方便地引用同一個或幾個攔截器,可以使用攔截器棧將這些攔截器作為一個整體來引用。攔截器棧要在標籤中使用和子標籤來定義。程式碼如下:
比爾
可以象使用攔截器一樣使用攔截器棧,如上面程式碼所示。
Struts2的攔截器和Servlet過濾器類似。在執行Action的execute方法之前,Struts2會首先執行在struts.xml中引用的攔截器,在執行完攔截器後,最後會執行Action的execute方法。
Struts2攔截器類必須從com.opensymphony.xwork2.interceptor.Interceptor介面繼承,在Intercepter介面中有如下三個方法需要實現:
void destroy();
void init();
String intercept(ActionInvocation invocation) throws Exception;
其中intercept方法是攔截器的核心方法,所有安裝的攔截器都會呼叫之個方法。在Struts2中已經在struts-default.xml中預定義了一些自帶的攔截器,如timer、params等。如果在
在struts-default.xml中有一個預設的引用,在預設情況下(也就是
dojo..*
input,back,cancel,browse
input,back,cancel,browse
上面在defaultStack中引用的攔截器都可以在
下面我們來看幾個簡單的攔截器的使用方法。
一、記錄攔截器和execute方法的執行時間(timer)
timer是Struts2中最簡單的攔截器,這個攔截器對應的類是com.opensymphony.xwork2.interceptor.TimerInterceptor。它的功能是記錄execute方法和其他攔截器(在timer後面定義的攔截器)的intercept方法執行的時間總和。如下面的配置程式碼所示:
由於在timer後面沒有其他的攔截器定義,因此,timer只能記錄execute方法的執行時間,在訪問first動作時,會在控制檯輸出類似下面的一條資訊:
資訊: Executed action [/test/first!execute] took 16 ms.
在使用timer攔截器時,需要commons-logging.jar的支援。將logger引用放到timer的後面,就可以記錄logger攔截器的intercept方法和Action的execute方法的執行時間總和,程式碼如下:
大家可以使用如下的Action類來測試一下timer攔截器:
package action;
import com.opensymphony.xwork2.ActionSupport;
public class FirstAction extends ActionSupport
{
public String execute() throws Exception
{
Thread.sleep(1000); // 延遲1秒
return null;
}
}
如果只記錄execute方法的執行時間,一般會輸出如下的資訊:
資訊: Executed action [/test/first!execute] took 1000 ms.
二、通過請求呼叫Action的setter方法(params)
當客戶端的一個form向服務端提交請求時,如有一個textfield,程式碼如下:
在提交後,Struts2將會自動呼叫first動作類中的setName方法,並將name文字框中的值通過setName方法的引數傳入。實際上,這個操作是由params攔截器完成的,params對應的類是com.opensymphony.xwork2.interceptor.ParametersInterceptor。由於params已經在defaultStack中定義,因此,在未引用攔截器的
... ...
但如果在
三、通過配置引數呼叫Action的setter方法(static-params)
通過使用
比爾
如果first動作使用上面的配置,在訪問first動作時,Struts2會自動呼叫setWho方法將“比爾”作為引數值傳入setWho方法。
四、使用攔截器棧
為了能在多個動作中方便地引用同一個或幾個攔截器,可以使用攔截器棧將這些攔截器作為一個整體來引用。攔截器棧要在
比爾
可以象使用攔截器一樣使用攔截器棧,如上面程式碼所示。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/12921506/viewspace-259935/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Struts2 ---攔截器的理解
- Struts2自定義攔截器
- Struts2攔截器實現原理
- 【Struts2】:攔截器實現方法過濾
- Struts2中攔截器的簡單實現
- 攔截器,攔截器棧總結
- Struts2 原始碼分析-----攔截器原始碼解析 --- ParametersInterceptor原始碼
- struts2的execAndWait攔截器使用AI
- MyBatis攔截器MyBatis
- Mybatis 攔截器MyBatis
- sql攔截器SQL
- Spring MVC 中的攔截器的使用“攔截器基本配置” 和 “攔截器高階配置”SpringMVC
- SpringMVC攔截器,設定不攔截的URLSpringMVC
- axios攔截器iOS
- Mybatis Interceptor 攔截器MyBatis
- axios 攔截器iOS
- spring攔截器Spring
- Java interceptor 攔截器Java
- SpringMVC攔截器SpringMVC
- vue中用axios攔截器攔截請求和響應VueiOS
- Flume內建攔截器與自定義攔截器(程式碼實戰)
- SpringMVC-攔截器SpringMVC
- 攔截過濾器模式過濾器模式
- gRPC(3):攔截器RPC
- 【SpringMVC】 4.3 攔截器SpringMVC
- web api新增攔截器WebAPI
- spring boot 攔截器Spring Boot
- SpringMVC配置攔截器SpringMVC
- Mybatis中的攔截器MyBatis
- mybatis註冊攔截器MyBatis
- HandlerInterceptor - 自定義攔截器
- SpringBoot攔截器中獲取註解、攔截器中注入ServiceSpring Boot
- struts struts攔截器(過濾器)過濾器
- Hi. 那位高手知道,如何在 Struts2 中使用 java 註釋,配置攔截器.Java
- webwork的攔截器真是好用Web
- Java實現的攔截器Java
- Spring Boot新增攔截器Spring Boot
- grpc中的攔截器RPC