您好,登錄后才能下訂單哦!
本篇文章為大家展示了Interceptor與Filter在SpringMVC中有什么不同,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
Interceptor
主要作用:攔截用戶請求,進行處理,比如判斷用戶登錄情況、權限驗證,只要針對Controller請求進行處理,是通過HandlerInterceptor。
Interceptor分兩種情況,一種是對會話的攔截,實現spring的HandlerInterceptor接口并注冊到mvc的攔截隊列中,其中preHandle()方法在調用Handler之前進行攔截(上圖步驟3),postHandle()方法在視圖渲染之前調用(上圖步驟5),afterCompletion()方法在返回相應之前執行;另一種是對方法的攔截,需要使用@Aspect注解,在每次調用指定方法的前、后進行攔截。
Filter
主要作用:過濾字符編碼、做一些業務邏輯判斷,主要用于對用戶請求進行預處理,同時也可進行邏輯判斷。
Filter在請求進入servlet容器執行service()方法之前就會經過filter過濾(上圖步驟1),不像Intreceptor一樣依賴于springmvc框架,只需要依賴于servlet。Filter啟動是隨WEB應用的啟動而啟動,只需要初始化一次,以后都可以進行攔截。
Filter有如下幾個種類:
用戶授權Filter:檢查用戶請求,根據請求過濾用戶非法請求;
日志Filter:記錄某些特殊的用戶請求;
解碼Filter:對非標準編碼的請求解碼。
Filter和Interceptor的區別
Filter是基于函數回調(doFilter()方法)的,而Interceptor則是基于Java反射的(AOP思想)。
Filter依賴于Servlet容器,而Interceptor不依賴于Servlet容器。
Filter對幾乎所有的請求起作用,而Interceptor只能對action請求起作用。
Interceptor可以訪問Action的上下文,值棧里的對象,而Filter不能。
在action的生命周期里,Interceptor可以被多次調用,而Filter只能在容器初始化時調用一次。
Filter在過濾是只能對request和response進行操作,而interceptor可以對request、response、handler、modelAndView、exception進行操作。
Interceptor
配置如下:
<mvc:interceptors> <bean class="cn.appsys.testInterceptor"></bean>//攔截所有請求 <mvc:interceptor> <mvc:mapping path="/manager/backend/**"/> <bean class="cn.appsys.interceptor.SysInterceptor"/>//攔截上面請求 </mvc:interceptor> </mvc:interceptors>
一般攔截器可通過實現HandlerInterceptor接口或者繼承HandlerInterceptorAdapter實現。代碼如下:
public class TestInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o) throws Exception { System.out.println("preHandle"); return true; } @Override public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception { System.out.println("postHandle"); } @Override public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception { System.out.println("afterCompletion"); } }
preHandle是在請求到達Controller之前實現,可進行用戶校驗登錄等操作,返回true后,請求到達Controller層;postHandle方法是在執行完Controller層代碼之后,DispatcherServlet進行視圖的渲染之前
執行,因此可以對ModelAndView 對象進行處理;afterCompletion方法是在DispatcherServlet進行視圖的渲染之后執行調用,主要是進行一些資源清理等工作。
注:只能對Controller請求進行攔截,對一些靜態資源無法攔截。
Filter
主要作用:統一設置字符集等。
依賴于servlet容器,過濾器實例只在初始化的時候調用一次。
過濾器在web.xml配置如下:
<filter> <filter-name>testFilter</filter-name> <filter-class>cn.appsys.TestFilter</filter-class> </filter> <filter-mapping> <filter-name>testFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
一般過濾器可通過實現Filter接口實現。代碼如下:
public class TestFilter implements Filter { @Override public void destroy() { System.out.println("filter destroy"); } @Override public void doFilter(ServletRequest arg0, ServletResponse arg1, FilterChain arg2) throws IOException, ServletException { System.out.println("filter doFilter before"); arg2.doFilter(arg0, arg1); System.out.println("filter doFilter after"); } @Override public void init(FilterConfig arg0) throws ServletException { System.out.println("filter init"); } }
攔截器和過濾器執行順序:
1、Filter.init();
2、Filter.doFilter(); before doFilter
3、HandlerInterceptor.preHandle();
4、Controller方法執行
5、HandlerInterceptor.postHandle();
6、DispatcherServlet視圖渲染
7、HandlerInterceptor.afterCompletion();
8、Filter.doFilter(); after doFilter
9、Filter.destroy();
上述內容就是Interceptor與Filter在SpringMVC中有什么不同,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。