国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

歡迎使用CSDN-markdown編輯器

2019-11-11 07:00:30
字體:
來源:轉載
供稿:網友

今天學習和認識了一下,過濾器和SPRingMVC的攔截器的區別,學到了不少的東西,以前一直以為攔截器就是過濾器實現的,現在想想還真是一種錯誤啊,而且看的比較粗淺,沒有一個全局而又細致的認識,由于已至深夜,時間原因,我就把一些網友的觀點重點摘錄下來,大家仔細看后也一定會有一個比較新的認識(在此非常感謝那些大牛們的無私奉獻,分享他們的經驗與心得,才能讓像我這樣的小白有機會站一下你們這些巨人的肩膀,才能少走些彎路)。

  過濾器和攔截器的區別:

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

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

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

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

@Overridepublic 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.攔截器是被包裹在過濾器之中的。

@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { System.out.println("preHandle"); return true;}@Overridepublic void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { System.out.println("postHandle");}@Overridepublic 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

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 二连浩特市| 二连浩特市| 鄂托克旗| 阿巴嘎旗| 南陵县| 昌图县| 阜平县| 甘洛县| 油尖旺区| 黄浦区| 从江县| 剑阁县| 香河县| 云霄县| 桃源县| 改则县| 嘉黎县| 阜城县| 青龙| 曲靖市| 商河县| 松阳县| 西城区| 宝兴县| 霞浦县| 岗巴县| 滕州市| 揭阳市| 唐山市| 社旗县| 盈江县| 东乌| 高雄市| 遵义县| 琼结县| 古蔺县| 定远县| 新龙县| 康保县| 新绛县| 北票市|