Spring MVC 攔截器 interceptor 用法詳解
Spring MVC-攔截器今天就是把有關攔截器的知識做一個總結。
1.攔截器概述
1.1 什么是攔截器?
Spring MVC中的攔截器(Interceptor)類似于Servlet中的過濾器(Filter),它主要用于攔截用戶請求并作相應的處理。例如通過攔截器可以進行權限驗證、記錄請求信息的日志、判斷用戶是否登錄等。要使用Spring MVC中的攔截器,就需要對攔截器類進行定義和配置。通常攔截器類可以通過兩種方式來定義。
1.通過實現(xiàn)HandlerInterceptor接口,或繼承HandlerInterceptor接口的實現(xiàn)類(如HandlerInterceptorAdapter)來定義。
2.通過實現(xiàn)WebRequestInterceptor接口,或繼承WebRequestInterceptor接口的實現(xiàn)類來定義。
以實現(xiàn)HandlerInterceptor接口方式為例,自定義攔截器類的代碼如下:
package com.mmm.interceptors;import org.springframework.web.servlet.HandlerInterceptor;import org.springframework.web.servlet.ModelAndView;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;/*** 創(chuàng)建自定義的攔截器01.務必實現(xiàn) HandlerInterceptor!02.我們使用的攔截器其實就是針對于Handler的攔截器===》處理器攔截器03.核心控制器中的HandleMapping返回的就是一個處理器執(zhí)行鏈 = Handler+ Interceptors(處理器攔截器)*/public class MyInterceptor implements HandlerInterceptor{/**** @param request* @param response* @param handler 打印出來com.mmm.controller.UserController@6225177c* @return* @throws Exception*** HandlerInterceptor接口中的三個方法:01.preHandle 如果返回值是false,則不會執(zhí)行后續(xù)的操作! 一個攔截器preHandle如果返回值是true 則會執(zhí)行下一個攔截器。。02.如果有多個攔截器,則之后攔截器中的所有方法都不會執(zhí)行!*/@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {System.out.println('執(zhí)行了 攔截器1111中的 ===》preHandle');return true;}/*** 之后指定了對應Handler中的方法之后 才執(zhí)行!* @param modelAndView 打印出來 ModelAndView: reference to view with name ’success’; model is {welcome=恭喜您登錄成功}* @throws Exception*/@Overridepublic void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {System.out.println('執(zhí)行了 攔截器1111中的===》postHandle');}/*** 只要是當前攔截器中的preHandle返回true則此方法必須執(zhí)行!* @param handler 打印出來com.mmm.controller.UserController@6225177c* @param ex* @throws Exception*/@Overridepublic void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {System.out.println('執(zhí)行了 攔截器1111的 ===》afterCompletion');}}
上述代碼中,自定義攔截器實現(xiàn)了HandlerInterceptor接口,并實現(xiàn)了接口中的三個方法:
preHandle() 方法:該方法會在控制器方法前執(zhí)行,其返回值表示是否中斷后續(xù)操作。當其返回值為true時,表示繼續(xù)向下執(zhí)行;當其返回值為false時,會中斷后續(xù)的所有操作(包括調用下一個攔截器和控制器類中的方法執(zhí)行等)。
postHandle()方法:該方法會在控制器方法調用之后,且解析視圖之前執(zhí)行。可以通過此方法對請求域中的模型和視圖做出進一步的修改。
afterCompletion()方法:該方法會在整個請求完成,即視圖渲染結束之后執(zhí)行。可以通過此方法實現(xiàn)一些資源清理、記錄日志信息等工作。
1.2 攔截器的配置
開發(fā)攔截器就像開發(fā)servlet或者filter一樣,都需要在配置文件進行配置,配置代碼如下:
<!--配置自定義的攔截器--><mvc:interceptors><!--攔截器1--><mvc:interceptor><!--配置攔截器的作用路徑--><mvc:mapping path= '/user/**'/><!--攔截的路徑規(guī)則--><!--定義在<mvc:interceptor>下面的表示匹配指定路徑的請求才進行攔截--><bean/></mvc:interceptor><!--攔截器2--><mvc:interceptor><mvc:mapping path='/user/**'/><!--攔截的路徑規(guī)則--><bean/></mvc:interceptor></mvc:interceptors>
上面的代碼中,<mvc:interceptors>元素用于配置一組攔截器,基子元素<bean>中定義的是全局攔截器,它會攔截所有的請求;而<mvc:interceptor>元素中定義的是指定路徑的攔截器,它會對指定路徑下的請求生效。<mvc:interceptor>元素的子元素<mvc:mapping>用于配置攔截器作用的路徑,該路徑在其屬性path 中定義。如上述代碼中 path 的屬性值“/**” 表示攔截所有路徑,“/hello” 表示攔截所有以 “/hello” 結尾的路徑。如果在請求路徑中包含不需要攔截的內容,還可以通過<mvc:exclude-mapping>元素進行配置。注意:<mvc:interceptor>中的子元素必須按照上述代碼中的配置順序進行編寫,即<mvc:mapping> <mvc:exclude-mapping> <bean>,否則文件會報錯。
2. 攔截器的執(zhí)行流程
1.程序先執(zhí)行preHandle()方法,如果該方法的返回值為true,則程序會繼續(xù)向下執(zhí)行處理器中的方法,否則將不再向下執(zhí)行。
2.在業(yè)務處理器(即控制器Controller類)處理完請求后,會執(zhí)行postHandle()方法,然后會通過DispatcherServlet向客戶端返回響應。
3.在DispatcherServlet處理完請求后,才會執(zhí)行afterCompletion()方法。
進入了 login執(zhí)行了 攔截器1111中的 ===》preHandle執(zhí)行了 攔截器2222中的 ===》preHandle進入了 main執(zhí)行了 攔截器2222中的===》postHandle執(zhí)行了 攔截器1111中的===》postHandle執(zhí)行了 攔截器2222的 ===》afterCompletion執(zhí)行了 攔截器1111的 ===》afterCompletion
到此這篇關于Spring MVC 攔截器 interceptor 用法詳解的文章就介紹到這了,更多相關Spring MVC 攔截器 interceptor 內容請搜索好吧啦網以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章:
1. XML入門的常見問題(三)2. HTTP協(xié)議常用的請求頭和響應頭響應詳解說明(學習)3. ASP將數字轉中文數字(大寫金額)的函數4. XML在語音合成中的應用5. .NET Framework各版本(.NET2.0 3.0 3.5 4.0)區(qū)別6. jscript與vbscript 操作XML元素屬性的代碼7. 不要在HTML中濫用div8. php使用正則驗證密碼字段的復雜強度原理詳細講解 原創(chuàng)9. ASP基礎入門第四篇(腳本變量、函數、過程和條件語句)10. HTML5實戰(zhàn)與剖析之觸摸事件(touchstart、touchmove和touchend)
