攔截器和過濾器的區別

 

過濾器,是在java web中,你傳入的request,response提早過濾掉一些信息,或者提早html

              設置一些參數,而後再傳入servlet或者struts的 action進行業務邏輯,好比過java

              濾掉非法url(不是login.do的地址請求,若是用戶沒有登錄都過濾掉),或者在web

              傳入servlet或者 struts的action前統一設置字符集,或者去除掉一些非法字符編程

 

攔截器,是在面向切面編程的就是在你的service或者一個方法,前調用一個方法,或者函數

               在方法後調用一個方法好比動態代理就是攔截器的簡單實現,在你調用方法前url

               打印出字符串(或者作其它業務邏輯的操做),也能夠在你調用方法後打印出代理

               字符串,甚至在你拋出異常的時候作業務邏輯的操做。htm

攔截器與過濾器的區別 :對象

攔截器是基於java的反射機制的,而過濾器是基於函數回調。blog

攔截器不依賴與servlet容器,過濾器依賴與servlet容器。

攔截器只能對action請求起做用,而過濾器則能夠對幾乎全部的請求起做用。

攔截器能夠訪問action上下文、值棧裏的對象,而過濾器不能訪問。

在action的生命週期中,攔截器能夠屢次被調用,而過濾器只能在容器初始化時被調用一次

攔截器能夠獲取IOC容器中的各個bean,而過濾器就不行,這點很重要,在攔截器裏注入

一個service,能夠調用業務邏輯。

執行順序 :過濾前 - 攔截前 - Action處理 - 攔截後 - 過濾後。我的認爲過濾是一個橫向的過

程,首先把客戶端提交的內容進行過濾(例如未登陸用戶不能訪問內部頁面的處理);過濾通

事後,攔截器將檢查用戶提交數據的驗證,作一些前期的數據處理,接着把處理後的數據發

給對應的Action;Action處理完成返回後,攔截器還能夠作其餘過程(還沒想到要作啥),再向

上返回到過濾器的後續操做。

更多說明查看文章:

http://www.javashuo.com/article/p-pvuowdgn-r.html

相關文章
相關標籤/搜索