日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯網營銷解決方案
Struts2教程:攔截器概述

Struts2的攔截器和Servlet過濾器類似。在執(zhí)行Action的execute方法之前,Struts2會首先執(zhí)行在struts.xml中引用的攔截器,在執(zhí)行完所有引用的攔截器的intercept方法后,會執(zhí)行Action的execute方法。

網站建設哪家好,找成都創(chuàng)新互聯!專注于網頁設計、網站建設、微信開發(fā)、小程序定制開發(fā)、集團企業(yè)網站建設等服務項目。為回饋新老客戶創(chuàng)新互聯還提供了米林免費建站歡迎大家使用!

Struts2攔截器類必須從com.opensymphony.xwork2.interceptor.Interceptor接口繼承,在Intercepter接口中有如下三個方法需要實現:

 
 
 
  1. void destroy();  
  2. void init();  
  3. String intercept(ActionInvocation invocation) throws Exception; 

其中intercept方法是攔截器的核心方法,所有安裝的攔截器都會調用之個方法。在Struts2中已經在struts-default.xml中預定義了一些自帶的攔截器,如timer、params等。如果在< package>標簽中繼承struts-default,則當前package就會自動擁有struts-default.xml中的所有配置。代碼如下:

< package name="demo" extends="struts-default" > ... < /package>

在struts-default.xml中有一個默認的引用,在默認情況下(也就是< action>中未引用攔截器時)會自動引用一些攔截器。這個默認的攔截器引用如下:

 
 
 
  1. < default-interceptor-ref name="defaultStack"/> 
  2.  
  3. < interceptor-stack name="defaultStack">     
  4.     < interceptor-ref name="exception"/> 
  5.     < interceptor-ref name="alias"/> 
  6.     < interceptor-ref name="servletConfig"/> 
  7.     < interceptor-ref name="prepare"/> 
  8.     < interceptor-ref name="i18n"/> 
  9.     < interceptor-ref name="chain"/> 
  10.     < interceptor-ref name="debugging"/> 
  11.     < interceptor-ref name="profiling"/> 
  12.     < interceptor-ref name="scopedModelDriven"/> 
  13.     < interceptor-ref name="modelDriven"/> 
  14.     < interceptor-ref name="fileUpload"/> 
  15.     < interceptor-ref name="checkbox"/> 
  16.     < interceptor-ref name="staticParams"/> 
  17.     < interceptor-ref name="params"> 
  18.         < param name="excludeParams">dojo\..*< /param> 
  19.     < /interceptor-ref> 
  20.     < interceptor-ref name="conversionError"/> 
  21.     < interceptor-ref name="validation"> 
  22.            < param name="excludeMethods">input,back,cancel,browse< /param> 
  23.      < /interceptor-ref> 
  24.      < interceptor-ref name="workflow"> 
  25.             < param name="excludeMethods">input,back,cancel,browse< /param> 
  26.      < /interceptor-ref> 
  27. < /interceptor-stack> 

上面在defaultStack中引用的攔截器都可以在< action>中不經過引用就可以使用(如果在< action>中引用了任何攔截器后,要使用在defaultStack中定義的攔截器,也需要在< action>中重新引用,在后面將詳細講解)。

下面我們來看幾個簡單的攔截器的使用方法。

一、記錄攔截器和execute方法的執(zhí)行時間(timer)

     timer是Struts2中最簡單的攔截器,這個攔截器對應的類是com.opensymphony.xwork2.interceptor.TimerInterceptor。它的功能是記錄execute方法和其他攔截器(在timer后面定義的攔截器)的intercept方法執(zhí)行的時間總和。如下面的配置代碼所示:

 
 
 
  1. < action name="first" class="action.FirstAction"> 
  2.     < interceptor-ref name="logger"/> 
  3.     < interceptor-ref name="timer" /> 
  4. < /action> 

由于在timer后面沒有其他的攔截器定義,因此,timer只能記錄execute方法的執(zhí)行時間,在訪問first動作時,會在控制臺輸出類似下面的一條信息:

信息: Executed action [/test/first!execute] took 16 ms.

在使用timer攔截器時,需要commons-logging.jar的支持。將logger引用放到timer的后面,就可以記錄logger攔截器的intercept方法和Action的execute方法的執(zhí)行時間總和,代碼如下:

 
 
 
  1. < action name="first" class="action.FirstAction"> 
  2.     < interceptor-ref name="timer" /> 
  3.     < interceptor-ref name="logger"/> 
  4. < /action> 

大家可以使用如下的Action類來測試一下timer攔截器:

 
 
 
  1. package action;  
  2.  
  3. import com.opensymphony.xwork2.ActionSupport;  
  4.  
  5. public class FirstAction extends ActionSupport            
  6.  
  7. {  
  8.        public String execute() throws Exception  
  9.  
  10.        {  
  11.            Thread.sleep(1000); // 延遲1秒  
  12.            return null;  
  13.        }  
  14.  
  15. }  

如果只記錄execute方法的執(zhí)行時間,一般會輸出如下的信息:

信息: Executed action [/test/first!execute] took 1000 ms.

二、通過請求調用Action的setter方法(params)

當客戶端的一個form向服務端提交請求時,如有一個textfield,代碼如下:

 
 
 
  1. < s:form action="first" namespace="/test"> 
  2.    < s:textfield name="name"/> 
  3.    < s:submit/> 
  4. < /s:form> 

在提交后,Struts2將會自動調用first動作類中的setName方法,并將name文本框中的值通過setName方法的參數傳入。實際上,這個操作是由params攔截器完成的,params對應的類是com.opensymphony.xwork2.interceptor.ParametersInterceptor。由于params已經在defaultStack中定義,因此,在未引用攔截器的< action>中是會自動引用params的,如下面的配置代碼,在訪問first動作時,Struts2是會自動執(zhí)行相應的setter方法的。

< action name="first" class="action.FirstAction">

    ... ...

< /action>

但如果在< action>中引用了其他的攔截器,就必須再次引用params攔截器,Struts2才能調用相應的setter方法。如下面的配置代碼所示:

 
 
 
  1. < action name="first" class="action.FirstAction"> 
  2.     < interceptor-ref name="timer" /> 
  3.     < interceptor-ref name="params"/> 
  4. < /action> 

三、通過配置參數調用Action的setter方法(static-params)

static-params攔截器可以通過配置< params>標簽來調用Action類的相應的setter方法,static-params攔截器對應的類是com.opensymphony.xwork2.interceptor.StaticParametersInterceptor。
    下面配置代碼演示了如何使用static-params攔截器:

 
 
 
  1. < action name="first" class="action.FirstAction"> 
  2.     < interceptor-ref name="timer" /> 
  3.     < param name="who">比爾< /param> 
  4.     < interceptor-ref name="params"/> 
  5.     < interceptor-ref name="static-params"/> 
  6. < /action> 

如果first動作使用上面的配置,在訪問first動作時,Struts2會自動調用setWho方法將“比爾”作為參數值傳入setWho方法。

四、使用攔截器棧

為了能在多個動作中方便地引用同一個或幾個攔截器,可以使用攔截器棧將這些攔截器作為一個整體來引用。攔截器棧要在< package>標簽中使用< interceptors>和子標簽< interceptor-stack>來定義。代碼如下:

 
 
 
  1. < package name="demo" extends="struts-default" > 
  2.     < interceptors> 
  3.         < interceptor-stack name="mystack"> 
  4.             < interceptor-ref name="timer" /> 
  5.             < interceptor-ref name="logger" /> 
  6.             < interceptor-ref name="params" /> 
  7.             < interceptor-ref name="static-params" /> 
  8.         < /interceptor-stack> 
  9.     < /interceptors> 
  10.  
  11.     < action name="first" class="action.FirstAction"> 
  12.         < param name="who">比爾< /param> 
  13.         < interceptor-ref name="mystack"/>              
  14.     < /action> 
  15. < /package> 

可以象使用攔截器一樣使用攔截器棧,如上面代碼所示。


名稱欄目:Struts2教程:攔截器概述
網頁地址:http://www.5511xx.com/article/dpejdds.html