Filter過濾器:攔截web訪問url地址。
Interceptor攔截器:攔截以 .action結尾的url,攔截Action的訪問。
Spring AOP攔截器:只能攔截Spring管理Bean的訪問(業務層Service)
----------------------------------------------------------------------------
Spring AOP
Spring AOP,是AOP的一種實現,使用的是代理模式。
Filter
Filter(過濾器)是J2EE的規范,Servlet2.3開始引入/實現的是職責鏈模式。Filter可以用來設置字符集、控制權限、控制轉向等等。Filter也是AOP的一種實現。
Interceptor
Interceptor (攔截器),是Struct2中的概念。同樣是AOP的一種實現。
Filter與Interceptor聯系與區別
1. 攔截器是基於java的反射機制,使用代理模式,而過濾器是基於函數回調。 2. 攔截器不依賴servlet容器,過濾器依賴於servlet容器。 3. 攔截器只能對action起作用,而過濾器可以對幾乎所有的請求起作用(可以保護資源)。 4. 攔截器可以訪問action上下文,堆棧里面的對象,而過濾器不可以。
5. 執行順序:過濾前-攔截錢-Action處理-攔截后-過濾后。
----------------------------------------------------------------------------
攔截器和過濾器的區別:
1、攔截器是基於Java的反射機制,過濾器是基於java的函數回調
2、攔截器不依賴於servlet容器,而過濾器依賴於servlet容器
3、攔截器只能對action請求起作用,過濾器幾乎對所有的請求起作用
4、攔截器可以訪問action上下文,值棧里的對象,而過濾器不能訪問
5、在action生命周期中,攔截器可以被多次調用,過濾器只能在servlet溶初始化是調用一次
6、攔截器可以獲取IOC容器中的各個bean,過濾器不行,在攔截器中注入一個service可以調用邏輯業務

攔截器:
Servlet中的過濾器Filter是實現了統一設置編碼,簡化操作;同時還可進行邏輯判斷,如用戶是否已經登陸、有沒有權限訪問該頁面等等工作。它是隨你的web應用啟動而啟動的,只初始化一次,以后就可以攔截相關請求,只有當你的web應用停止或重新部署的時候才銷毀
過濾器:
攔截器是在面向切面編程中應用的,就是在你的service或者一個方法前調用一個方法,或者在方法后調用一個方法。是基於JAVA的反射機制。攔截器不是在web.xml,比如struts在struts.xml中配置,
總結:
1.過濾器:所謂過濾器顧名思義是用來過濾的,在Java web中,你傳入的request,response提前過濾掉一些信息,或者提前設置一些參數,然后再傳入servlet或者struts的action進行業務邏輯,比如過濾掉非法url(不是login.do的地址請求,如果用戶沒有登陸都過濾掉),或者在傳入servlet或者struts的action前統一設置字符集,或者去除掉一些非法字符(聊天室經常用到的,一些罵人的話)。filter 流程是線性的, url傳來之后,檢查之后,可保持原來的流程繼續向下執行,被下一個filter, servlet接收等.
2.java的攔截器 主要是用在插件上,擴展件上比如 hivernate spring struts2等 有點類似面向切片的技術,在用之前先要在配置文件即xml文件里聲明一段的那個東西。