Springboot項目Aop與攔截器與過濾器橫向?qū)Ρ?/h1>
更新時間:2023年03月28日 09:40:33 作者:凡夫販夫
前三篇文章已經(jīng)介紹過Springboot項目如何實現(xiàn)Aop,攔截器和過濾齊功能,這篇文章主要介紹三者的橫向?qū)Ρ?,本文有一定的參考價值,感興趣的小伙伴可以參考閱讀
前言
偉人曾經(jīng)說過,沒有調(diào)查就沒有發(fā)言權(quán)(好像是偉人說的,不管誰說的,這句話是正確的),有些東西看著簡單,張口就來,但很有可能是錯的。我個人的經(jīng)驗是,aop、過濾器、攔截器的實現(xiàn)方式很簡單,一學(xué)就會,不用就忘,忘了再學(xué),學(xué)了再忘,如此循環(huán)內(nèi)耗何必呢?因此,如果你和我一樣,有一顆強烈的好奇之心,那么不管多簡單,動手敲起來吧,溫故而知新呢。
功能特性對比
過濾器
過濾器(Filter)是與servlet相關(guān)聯(lián)的一個接口,主要適用于java web項目中,依賴于Servlet容器,是利用java的回調(diào)機制來實現(xiàn)過濾攔截來自瀏覽器端的http請求,可以攔截到訪問URL對應(yīng)的方法的請求和響應(yīng)(ServletRequest request, ServletResponse response),但是不能對請求和響應(yīng)信息中的值進行修改;一般用于設(shè)置字符編碼、鑒權(quán)操作等;如果想要做到更細一點的類和方法或者是在非servlet環(huán)境中使用,則是做不到的;所以凡是依賴Servlet容器的環(huán)境,過濾器都可以使用,如Struts2、SpringMVC;

攔截器
攔截器的(HandlerInterceptor)使用范圍以及功能和過濾器很類似,但是也是有區(qū)別的。首先,攔截器(HandlerInterceptor)適用于SpringMVC中,因為HandlerInterceptor接口是SpringMVC相關(guān)的一個接口,而實現(xiàn)java Web項目,SpringMVC是目前的首選選項,但不是唯一選項,還有struts2等;因此,如果是非SpingMVC的項目,HandlerInterceptor無法使用的;其次,和過濾器一樣,攔截器可以攔截到訪問URL對應(yīng)的方法的請求和響應(yīng)(ServletRequest request, ServletResponse response),但是不能對請求和響應(yīng)信息中的值進行修改;一般用于設(shè)置字符編碼、鑒權(quán)操作等;如果想要做到更細一點的類和方法或者是在非servlet環(huán)境中使用,則也是是做不到的;
總之,過濾器和攔截器的功能很類似,但是攔截器的適用范圍比過濾器更??;

Spring AOP
AOP (Aspect Orient Programming),直譯過來就是 面向切面編程,AOP 是一種編程思想,是面向?qū)ο缶幊蹋∣OP)的一種補充。面向切面編程,可以實現(xiàn)在不修改源代碼的情況下給程序動態(tài)統(tǒng)一添加額外功能的一種技術(shù),AOP可以攔截指定的方法并且對方法增強,而且無需侵入到業(yè)務(wù)代碼中,使業(yè)務(wù)與非業(yè)務(wù)處理邏輯分離;而SpringAOP,則是AOP的一種具體實現(xiàn),Spring內(nèi)部對SpringAOP的應(yīng)用最經(jīng)典的場景就是Spring的事務(wù),通過事務(wù)注解的配置,Spring會自動在業(yè)務(wù)方法中開啟、提交業(yè)務(wù),并且在業(yè)務(wù)處理失敗時,執(zhí)行相應(yīng)的回滾策略;與過濾器、攔截器相比,更加重要的是其適用范圍不再局限于SpringMVC項目,可以在任意一層定義一個切點,織入相應(yīng)的操作,并且還可以改變返回值;

代碼實現(xiàn)
過濾器實現(xiàn)
傳送門:Springboot項目快速實現(xiàn)過濾器功能
攔截器實現(xiàn)
傳送門:Springboo項目快速實現(xiàn)攔截器功能
AOP實現(xiàn)
傳送門:Springboot項目快速實現(xiàn)Aop功能
實現(xiàn)示例源代碼地址:
https://gitcode.net/fox9916/fanfu-web.git(branch:Aop+filter+interceptor)
在實現(xiàn)示例中,主要的過濾器實現(xiàn)類、攔截器實現(xiàn)類和AOP實現(xiàn)類,與涉及到的接口之間的關(guān)系如下:

驗證結(jié)果
匹配中同一個目標(PersonController#getPerson())的情況下,過濾器、攔截器、SpringAOP的執(zhí)行優(yōu)先級是:
過濾器>攔截器>SpringAOP,執(zhí)行順序是先進后出;

工作原理
從驗證結(jié)果的輸出日志中,已經(jīng)可以看到,在匹配中同一目標時,過濾器、攔截器、SpringAOP的執(zhí)行優(yōu)先級是:過濾器>攔截器>SpringAOP,執(zhí)行順序是先進后出,具體的不同則體現(xiàn)在以下幾個方面:
1、作用域不同
- 過濾器依賴于servlet容器,只能在 servlet容器,web環(huán)境下使用,對請求-響應(yīng)入口處進行過濾攔截;
- 攔截器依賴于springMVC,可以在SpringMVC項目中使用,而SpringMVC的核心是DispatcherServlet,而DispatcherServlet又屬于Servlet的子類,因此作用域和過濾器類似;
- SpringAOP對作用域沒有限制,只要定義好切點,可以在請求-響應(yīng)的入口層(controller層)攔截處理,也可以在請求的業(yè)務(wù)處理層(service層)攔截處理;
2、顆粒度的不同
- 過濾器的控制顆粒度比較粗,只能在doFilter()中對請求和響應(yīng)進行過慮和攔截處理;
- 攔截器提供更精細顆粒度的控制,有preHandle()、postHandle()、afterCompletion(),可以在controller對請求處理之前、請求處理后、請求響應(yīng)完畢織入一些業(yè)務(wù)操作;
- SpringAOP,提供了前置通知、后置通知、返回后通知、異常通知、環(huán)繞通知,比攔截器更加精細化的顆粒度控制,甚至可以修改返回值;
總結(jié)
過濾器、攔截器、AOP本質(zhì)上來講,都是面向切面編程的實踐,只是在功能特性、適用范圍、實現(xiàn)細節(jié)上有一些區(qū)別。一般情況下,過濾器能實現(xiàn)的功能,攔截器也可以實現(xiàn);過濾器、攔截器可以實現(xiàn)的功能,AOP也可以實現(xiàn);那么在業(yè)務(wù)開發(fā)過程中作選型的時候,是不是直接用AOP就完了,其實我認為不能這樣,還是需要根據(jù)具體的業(yè)務(wù)環(huán)境和技術(shù)環(huán)境進行選擇,殺雞可必要用牛刀,你說呢?
以上就是Springboot項目Aop與攔截器與過濾器橫向?qū)Ρ鹊脑敿殐?nèi)容,更多關(guān)于Aop與攔截器與過濾器的對比的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
-
HttpClient 請求 URL字符集轉(zhuǎn)碼問題
這篇文章主要介紹了HttpClient 請求 URL字符集轉(zhuǎn)碼問題,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下 2021-01-01
-
Java學(xué)習(xí)基礎(chǔ)之安裝JDK/配置JDK環(huán)境&IEDA工具安裝
這篇文章主要介紹了Java學(xué)習(xí)基礎(chǔ)系列文章的第一篇,主要內(nèi)容是安裝JDK/配置JDK環(huán)境&IEDA工具安裝的相關(guān)資料,需要的朋友可以參考下 2020-02-02
-
springboot中動態(tài)權(quán)限實時管理的實現(xiàn)詳解
這篇文章主要為大家詳細介紹了如何簡單實現(xiàn)一個在springboot中動態(tài)權(quán)限的實時管理,文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下 2024-10-10
-
Java通過wait()和notifyAll()方法實現(xiàn)線程間通信
這篇文章主要為大家詳細介紹了Java通過wait()和notifyAll()方法實現(xiàn)線程間通信的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下 2017-04-04
最新評論
前言
偉人曾經(jīng)說過,沒有調(diào)查就沒有發(fā)言權(quán)(好像是偉人說的,不管誰說的,這句話是正確的),有些東西看著簡單,張口就來,但很有可能是錯的。我個人的經(jīng)驗是,aop、過濾器、攔截器的實現(xiàn)方式很簡單,一學(xué)就會,不用就忘,忘了再學(xué),學(xué)了再忘,如此循環(huán)內(nèi)耗何必呢?因此,如果你和我一樣,有一顆強烈的好奇之心,那么不管多簡單,動手敲起來吧,溫故而知新呢。
功能特性對比
過濾器
過濾器(Filter)是與servlet相關(guān)聯(lián)的一個接口,主要適用于java web項目中,依賴于Servlet容器,是利用java的回調(diào)機制來實現(xiàn)過濾攔截來自瀏覽器端的http請求,可以攔截到訪問URL對應(yīng)的方法的請求和響應(yīng)(ServletRequest request, ServletResponse response),但是不能對請求和響應(yīng)信息中的值進行修改;一般用于設(shè)置字符編碼、鑒權(quán)操作等;如果想要做到更細一點的類和方法或者是在非servlet環(huán)境中使用,則是做不到的;所以凡是依賴Servlet容器的環(huán)境,過濾器都可以使用,如Struts2、SpringMVC;

攔截器
攔截器的(HandlerInterceptor)使用范圍以及功能和過濾器很類似,但是也是有區(qū)別的。首先,攔截器(HandlerInterceptor)適用于SpringMVC中,因為HandlerInterceptor接口是SpringMVC相關(guān)的一個接口,而實現(xiàn)java Web項目,SpringMVC是目前的首選選項,但不是唯一選項,還有struts2等;因此,如果是非SpingMVC的項目,HandlerInterceptor無法使用的;其次,和過濾器一樣,攔截器可以攔截到訪問URL對應(yīng)的方法的請求和響應(yīng)(ServletRequest request, ServletResponse response),但是不能對請求和響應(yīng)信息中的值進行修改;一般用于設(shè)置字符編碼、鑒權(quán)操作等;如果想要做到更細一點的類和方法或者是在非servlet環(huán)境中使用,則也是是做不到的;
總之,過濾器和攔截器的功能很類似,但是攔截器的適用范圍比過濾器更??;

Spring AOP
AOP (Aspect Orient Programming),直譯過來就是 面向切面編程,AOP 是一種編程思想,是面向?qū)ο缶幊蹋∣OP)的一種補充。面向切面編程,可以實現(xiàn)在不修改源代碼的情況下給程序動態(tài)統(tǒng)一添加額外功能的一種技術(shù),AOP可以攔截指定的方法并且對方法增強,而且無需侵入到業(yè)務(wù)代碼中,使業(yè)務(wù)與非業(yè)務(wù)處理邏輯分離;而SpringAOP,則是AOP的一種具體實現(xiàn),Spring內(nèi)部對SpringAOP的應(yīng)用最經(jīng)典的場景就是Spring的事務(wù),通過事務(wù)注解的配置,Spring會自動在業(yè)務(wù)方法中開啟、提交業(yè)務(wù),并且在業(yè)務(wù)處理失敗時,執(zhí)行相應(yīng)的回滾策略;與過濾器、攔截器相比,更加重要的是其適用范圍不再局限于SpringMVC項目,可以在任意一層定義一個切點,織入相應(yīng)的操作,并且還可以改變返回值;

代碼實現(xiàn)
過濾器實現(xiàn)
傳送門:Springboot項目快速實現(xiàn)過濾器功能
攔截器實現(xiàn)
傳送門:Springboo項目快速實現(xiàn)攔截器功能
AOP實現(xiàn)
傳送門:Springboot項目快速實現(xiàn)Aop功能
實現(xiàn)示例源代碼地址:
https://gitcode.net/fox9916/fanfu-web.git(branch:Aop+filter+interceptor)
在實現(xiàn)示例中,主要的過濾器實現(xiàn)類、攔截器實現(xiàn)類和AOP實現(xiàn)類,與涉及到的接口之間的關(guān)系如下:

驗證結(jié)果
匹配中同一個目標(PersonController#getPerson())的情況下,過濾器、攔截器、SpringAOP的執(zhí)行優(yōu)先級是:
過濾器>攔截器>SpringAOP,執(zhí)行順序是先進后出;

工作原理
從驗證結(jié)果的輸出日志中,已經(jīng)可以看到,在匹配中同一目標時,過濾器、攔截器、SpringAOP的執(zhí)行優(yōu)先級是:過濾器>攔截器>SpringAOP,執(zhí)行順序是先進后出,具體的不同則體現(xiàn)在以下幾個方面:
1、作用域不同
- 過濾器依賴于servlet容器,只能在 servlet容器,web環(huán)境下使用,對請求-響應(yīng)入口處進行過濾攔截;
- 攔截器依賴于springMVC,可以在SpringMVC項目中使用,而SpringMVC的核心是DispatcherServlet,而DispatcherServlet又屬于Servlet的子類,因此作用域和過濾器類似;
- SpringAOP對作用域沒有限制,只要定義好切點,可以在請求-響應(yīng)的入口層(controller層)攔截處理,也可以在請求的業(yè)務(wù)處理層(service層)攔截處理;
2、顆粒度的不同
- 過濾器的控制顆粒度比較粗,只能在doFilter()中對請求和響應(yīng)進行過慮和攔截處理;
- 攔截器提供更精細顆粒度的控制,有preHandle()、postHandle()、afterCompletion(),可以在controller對請求處理之前、請求處理后、請求響應(yīng)完畢織入一些業(yè)務(wù)操作;
- SpringAOP,提供了前置通知、后置通知、返回后通知、異常通知、環(huán)繞通知,比攔截器更加精細化的顆粒度控制,甚至可以修改返回值;
總結(jié)
過濾器、攔截器、AOP本質(zhì)上來講,都是面向切面編程的實踐,只是在功能特性、適用范圍、實現(xiàn)細節(jié)上有一些區(qū)別。一般情況下,過濾器能實現(xiàn)的功能,攔截器也可以實現(xiàn);過濾器、攔截器可以實現(xiàn)的功能,AOP也可以實現(xiàn);那么在業(yè)務(wù)開發(fā)過程中作選型的時候,是不是直接用AOP就完了,其實我認為不能這樣,還是需要根據(jù)具體的業(yè)務(wù)環(huán)境和技術(shù)環(huán)境進行選擇,殺雞可必要用牛刀,你說呢?
以上就是Springboot項目Aop與攔截器與過濾器橫向?qū)Ρ鹊脑敿殐?nèi)容,更多關(guān)于Aop與攔截器與過濾器的對比的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
HttpClient 請求 URL字符集轉(zhuǎn)碼問題
這篇文章主要介紹了HttpClient 請求 URL字符集轉(zhuǎn)碼問題,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01
Java學(xué)習(xí)基礎(chǔ)之安裝JDK/配置JDK環(huán)境&IEDA工具安裝
這篇文章主要介紹了Java學(xué)習(xí)基礎(chǔ)系列文章的第一篇,主要內(nèi)容是安裝JDK/配置JDK環(huán)境&IEDA工具安裝的相關(guān)資料,需要的朋友可以參考下2020-02-02
springboot中動態(tài)權(quán)限實時管理的實現(xiàn)詳解
這篇文章主要為大家詳細介紹了如何簡單實現(xiàn)一個在springboot中動態(tài)權(quán)限的實時管理,文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下2024-10-10
Java通過wait()和notifyAll()方法實現(xiàn)線程間通信
這篇文章主要為大家詳細介紹了Java通過wait()和notifyAll()方法實現(xiàn)線程間通信的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04

