Struts2學(xué)習(xí)教程之攔截器機制與自定義攔截器
前言
攔截器體系是Struts2框架的重要組成部分,不夸張的說,沒有攔截器體系,也就沒有這么好用的Struts2框架了。在Struts2框架中,大量的攔截器完成了很多基礎(chǔ)的功能,比如,params攔截器負責(zé)解析HTTP請求的參數(shù),并設(shè)置Action的屬性;servlet-config攔截器直接將HTTP請求中的HttpServletRequest實例和HttpServletResponse實例傳給Action;fileUpload攔截器則負責(zé)解析請求參數(shù)中的文件域,并將一個文件域設(shè)置成Action的三個屬性......這一切的一切都是由內(nèi)建的攔截器來完成的。所以,掌握了Struts2中攔截器的使用原理與方式,也就把握住了Struts2框架的“命脈”。
但是學(xué)習(xí)Struts2到現(xiàn)在,除了在web.xml中配置了一個StrutsPrepareAndExecuteFilter過濾器外,還沒有接觸其它的什么攔截器,那為什么我們的應(yīng)用能夠很好的運行呢?實際上,Struts2已經(jīng)默認啟用了大量通用的攔截器,只要配置Action的package繼承了struts-default包,這些攔截器就會起作用。下面來看看Struts2內(nèi)建的攔截器。
Struts2內(nèi)建的攔截器
在Struts2框架中有很多內(nèi)建的攔截器,這些攔截器幾乎完成了Struts2框架70%的工作,包括解析請求參數(shù),將請求參數(shù)賦值給Action屬性等,Struts2這種靈巧的設(shè)計,很大程度上得益于攔截器的設(shè)計;當需要擴展Struts2功能時,只需要提供對應(yīng)攔截器,并將它配置在Struts2容器中即可。
這些內(nèi)建的攔截器以name-class對的形式配置在struts-default.xml文件中,其中name是攔截器名字,就是以后使用該攔截器的唯一標識;class則指定了該攔截器的實現(xiàn)類。對于這些內(nèi)建的攔截器的詳細介紹,請參見官方文檔。
配置攔截器
在Struts.xml文件中定義攔截器只需為攔截器類指定一個攔截器名,就完成了攔截器定義。定義攔截器使用<interceptor.../>,例如:
<!-- 通過指定攔截器名和攔截器實現(xiàn)類來定義攔截器 --> <interceptor name="攔截器名" class="攔截器實現(xiàn)類"> <param name="參數(shù)名">參數(shù)值</param> </interceptor>
除此之外,還可以把多個攔截器連在一起組成攔截器棧,在攔截器中使用<interceptor-ref .../>來定義攔截器引用。例如:
<interceptor-stack name="攔截器棧一"> <interceptor-ref name="攔截器一"/> <interceptor-ref name="攔截器二"/> ... </interceptor-stack>
從程序結(jié)構(gòu)上來看,攔截器棧由多個攔截器組成;但是從程序功能上來說,攔截器棧和攔截器是一樣的,它們包含的方法都會在Action的execute方法執(zhí)行之前自動執(zhí)行。所以,我們完全可以把攔截器棧當成一個更大的攔截器。
由于攔截器棧和攔截器是一致的,所以攔截器棧中又可以包含攔截器棧,例如:
<interceptor-stack name="攔截器棧二"> <interceptor-ref name="modelDriven"/> <interceptor-ref name="攔截器棧一"/> </interceptor-stack>
使用攔截器
一旦定義了攔截器棧和攔截器后,就可以使用這個攔截器?;驍r截器來攔截Action了,攔截器的攔截行為將會在Action的execute方法執(zhí)行之前被執(zhí)行。
通過使用<interceptor-ref .../>元素可以在Action內(nèi)使用攔截器,在Action中使用攔截器的配置語法與配置攔截器棧時引用攔截器的語法完全一樣。例如:
<action name="login" class="com.jellythink.practise.LoginAction"> <result name="error">/error.jsp</result> <result name="success">/welcome.jsp</result> <!-- 攔截器棧 --> <interceptor-ref name="defaultStack"/> <!-- 攔截器 --> <interceptor-ref name="test1"/> <!-- 帶參數(shù)的攔截器 --> <interceptor-ref name="test2"> <param name="key">動態(tài)參數(shù)</param> </interceptor-ref> </action>
這樣配置完成以后,在執(zhí)行DownloadAction之前,這三個攔截器都會起作用。
配置默認攔截器
當配置一個包時,可以為其指定默認攔截器。一旦為某個包指定了默認的攔截器,如果該包中的Action沒有顯式指定攔截器,則默認的攔截器將會起作用。但是,一旦我們?yōu)樵摪械腁ction顯式應(yīng)用了某個攔截器,則默認的攔截器不會起作用;如果該Action需要使用該默認攔截器,則必須手動配置該攔截器的引用。
只有當Action中沒有顯式應(yīng)用攔截器時,該Action所在包的默認攔截器才會生效。
配置默認攔截器使用<default-interceptor-ref.../>元素,該元素作為<package.../>元素的子元素使用,為該包下的所有Action配置默認的攔截器。例如:
<default-interceptor-ref name="默認攔截器"/>
也可以為默認攔截器指定參數(shù),例如:
<default-interceptor-ref name="默認攔截器"> <param name="參數(shù)名">參數(shù)值</param> </default-interceptor-ref>
在struts-default.xml文件中,配置了一個名為struts-default的抽象包,在該包中定義了名為defaultStack的默認攔截器引用。當我們定義的包繼承struts-default包時,也繼承了它的默認攔截器棧:defaultStack,這也意味著,如果我們不為Action顯式地應(yīng)用攔截器,則defaultStack攔截器棧會自動生效。
自定義攔截器
1>.添加一個類,讓它繼承AbstractInterceptor類,或者實現(xiàn)Interceptor接口
public class TimeInterceptor extends AbstractInterceptor { /** * 攔截器的核心方法intercept的返回值是一個字符串 */ @Override public String intercept(ActionInvocation invocation) throws Exception { // TODO Auto-generated method stub return "login"; } }
2>.在struts.xml的package中添加interceptors子節(jié)點,并在它下面添加Interceptor節(jié)點
<package name="goods" namespace="/goods" extends="common-pkg"> <interceptors> <interceptor name="timeInterceptor" class="com.wskj.struts2.interceptor.TimeInterceptor"></interceptor> </interceptors> </package>
3>.在想被攔截的action節(jié)點下添加子節(jié)點interceptor-ref
<action name="list_Category" class="com.wskj.struts2.controller.CategoryAction" method="list"> <interceptor-ref name="timeInterceptor"></interceptor-ref> <result name="list" type="dispatcher">/pages/Category/list.jsp</result> </action>
總結(jié)
這篇文章對Stuts2中的核心——攔截器進行了一個初步的總結(jié),在后面的文章中,我們會實現(xiàn)一個我們自己的攔截器,并將這篇文章中總結(jié)的知識點進行運用。
好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
Springboot+AOP實現(xiàn)時間參數(shù)格式轉(zhuǎn)換
前端傳過來的時間參數(shù),后端可以自定義時間格式轉(zhuǎn)化使用,這樣想轉(zhuǎn)成什么就轉(zhuǎn)成什么。本文將利用自定義注解AOP實現(xiàn)時間參數(shù)格式轉(zhuǎn)換,感興趣的可以了解一下2022-04-04MyBatis中如何接收String類型的參數(shù)實現(xiàn)
這篇文章主要介紹了MyBatis中如何接收String類型的參數(shù)實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02Sax解析xml_動力節(jié)點Java學(xué)院整理
這篇文章主要介紹了Sax解析xml,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-08-08java客戶端Etcd官方倉庫jetcd中KeepAlive接口實現(xiàn)
這篇文章主要為大家介紹了java客戶端Etcd官方倉庫jetcd中KeepAlive接口實現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,多多加薪2022-02-02redis實現(xiàn)多進程數(shù)據(jù)同步工具代碼分享
這篇文章主要介紹了使用redis實現(xiàn)多進程數(shù)據(jù)同步工具的代碼,大家參考使用吧2014-01-01SpringMvc直接接收json數(shù)據(jù)自動轉(zhuǎn)化為Map的實例
今天小編就為大家分享一篇SpringMvc直接接收json數(shù)據(jù)自動轉(zhuǎn)化為Map的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08