Java過濾器與SpringMVC攔截器之間的關係與區別

來源:互聯網
上載者:User

標籤:ioc   blog   ada   分發   alt   href   .net   cep   函數   

過濾器和攔截器的區別:

  ①攔截器是基於Java的反射機制的,而過濾器是基於函數回調。
  ②攔截器不依賴與servlet容器,過濾器依賴與servlet容器。
  ③攔截器只能對action請求起作用,而過濾器則可以對幾乎所有的請求起作用。
  ④攔截器可以訪問action上下文、值棧裡的對象,而過濾器不能訪問。
  ⑤在action的生命週期中,攔截器可以多次被調用,而過濾器只能在容器初始化時被調用一次。

  ⑥攔截器可以擷取IOC容器中的各個bean,而過濾器就不行,這點很重要,在攔截器裡注入一個service,可以調用商務邏輯。

  寫了點測試代碼,順便整理一下思路,搞清楚這幾者之間的順序:

  1.過濾器是JavaEE標準,採用函數回調的方式進行。是在請求進入容器之後,還未進入Servlet之前進行預先處理,並且在請求結束返回給前端這之間進行後期處理。

 
    @Override    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {        System.out.println("before...");        chain.doFilter(request, response);        System.out.println("after...");    }
 

  chain.doFilter(request, response);這個方法的調用作為分水嶺。事實上調用Servlet的doService()方法是在chain.doFilter(request, response);這個方法中進行的。

  2.攔截器是被包裹在過濾器之中的。

 
    @Override    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {        System.out.println("preHandle");        return true;    }    @Override    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {        System.out.println("postHandle");    }    @Override    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {        System.out.println("afterCompletion");    }
 

  a.preHandle()這個方法是在過濾器的chain.doFilter(request, response)方法的前一步執行,也就是在 [System.out.println("before...")][chain.doFilter(request, response)]之間執行。

  b.preHandle()方法之後,在return ModelAndView之前進行,可以操控Controller的ModelAndView內容。

  c.afterCompletion()方法是在過濾器返回給前端前一步執行,也就是在[chain.doFilter(request, response)][System.out.println("after...")]之間執行。

  3.SpringMVC的機制是由同一個Servlet來分發請求給不同的Controller,其實這一步是在Servlet的service()方法中執行的。所以過濾器、攔截器、service()方法,dispatc()方法的執行順序應該是這樣的,大致畫了個圖:其實非常好測試,自己寫一個過濾器,一個攔截器,然後在這些方法中都加個斷點,一路F8下去就得出了結論。

  

 

 

  總結:攔截器功在對請求許可權評鑑方面確實很有用處,在我所參與的這個項目之中,第三方的遠程調用每個請求都需要參與評鑑,所以這樣做非常方便,而且他是很獨立的邏輯,這樣做讓商務邏輯代碼很乾淨。和架構的其他功能一樣,原理很簡單,使用起來也很簡單,大致看了下SpringMVC這一部分的源碼,其實還是比較容易理解的。

  我們項目中僅僅用到了preHandle這個方法,而未用其他的,架構提供了一個已經實現了攔截器介面的適配器類HandlerInterceptorAdapter,繼承這個類然後重寫一下需要用到的方法就行了,可以少幾行代碼,這種方式Java中很多地方都有體現。

以上部分是摘自神一樣存在的部落格,參考了一下這個文章:http://haohaoxuexi.iteye.com/blog/1750680

大家還可以參考一下這個電子書的:

Java過濾器與SpringMVC攔截器之間的關係與區別

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.