溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何進(jìn)行Struts2攔截器的使用分析

發(fā)布時(shí)間:2022-01-15 10:45:41 來源:億速云 閱讀:303 作者:柒染 欄目:編程語(yǔ)言

這篇文章給大家介紹如何進(jìn)行Struts2攔截器的使用分析,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

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

Struts2攔截器類必須從com.opensymphony.xwork2.interceptor.Interceptor接口繼承,在Intercepter接口中有如下三個(gè)方法需要實(shí)現(xiàn):

void destroy();  void init();  String intercept(ActionInvocation invocation) throws Exception;

其中intercept方法是攔截器的核心方法,所有安裝的攔截器都會(huì)調(diào)用之個(gè)方法。在Struts2中已經(jīng)在struts-default.xml中預(yù)定義了一些自帶的攔截器,如timer、params等。如果在< package>標(biāo)簽中繼承struts-default,則當(dāng)前package就會(huì)自動(dòng)擁有struts-default.xml中的所有配置。代碼如下:

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

在struts-default.xml中有一個(gè)默認(rèn)的引用,在默認(rèn)情況下(也就是< action>中未引用攔截器時(shí))會(huì)自動(dòng)引用一些攔截器。這個(gè)默認(rèn)的攔截器引用如下:

< default-interceptor-ref name="defaultStack"/>  < interceptor-stack name="defaultStack">         < interceptor-ref name="exception"/>     < interceptor-ref name="alias"/>     < interceptor-ref name="servletConfig"/>     < interceptor-ref name="prepare"/>     < interceptor-ref name="i18n"/>     < interceptor-ref name="chain"/>     < interceptor-ref name="debugging"/>     < interceptor-ref name="profiling"/>     < interceptor-ref name="scopedModelDriven"/>     < interceptor-ref name="modelDriven"/>     < interceptor-ref name="fileUpload"/>     < interceptor-ref name="checkbox"/>     < interceptor-ref name="staticParams"/>     < interceptor-ref name="params">         < param name="excludeParams">dojo\..*< /param>     < /interceptor-ref>     < interceptor-ref name="conversionError"/>     < interceptor-ref name="validation">            < param name="excludeMethods">input,back,cancel,browse< /param>      < /interceptor-ref>      < interceptor-ref name="workflow">             < param name="excludeMethods">input,back,cancel,browse< /param>      < /interceptor-ref> < /interceptor-stack>

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

下面我們來看幾個(gè)簡(jiǎn)單的攔截器的使用方法。

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

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

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

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

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

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

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

大家可以使用如下的Action類來測(cè)試一下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方法的執(zhí)行時(shí)間,一般會(huì)輸出如下的信息:

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

二、通過請(qǐng)求調(diào)用Action的setter方法(params)

當(dāng)客戶端的一個(gè)form向服務(wù)端提交請(qǐng)求時(shí),如有一個(gè)textfield,代碼如下:

< s:form action="first" namespace="/test">    < s:textfield name="name"/>    < s:submit/> < /s:form>

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

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

... ...

< /action>

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

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

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

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

< action name="first" class="action.FirstAction">     < interceptor-ref name="timer" />     < param name="who">比爾< /param>     < interceptor-ref name="params"/>     < interceptor-ref name="static-params"/> < /action>

如果first動(dòng)作使用上面的配置,在訪問first動(dòng)作時(shí),Struts2會(huì)自動(dòng)調(diào)用setWho方法將“比爾”作為參數(shù)值傳入setWho方法。

四、使用攔截器棧

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

< package name="demo" extends="struts-default" >     < interceptors>         < interceptor-stack name="mystack">             < interceptor-ref name="timer" />             < interceptor-ref name="logger" />             < interceptor-ref name="params" />             < interceptor-ref name="static-params" />         < /interceptor-stack>     < /interceptors>      < action name="first" class="action.FirstAction">         < param name="who">比爾< /param>         < interceptor-ref name="mystack"/>                  < /action> < /package>

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

關(guān)于如何進(jìn)行Struts2攔截器的使用分析就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI