Spring Security的過濾器鏈機(jī)制
前言
在“碼農(nóng)小胖哥”的文章中提到一個(gè)關(guān)鍵的過濾器鏈SecurityFilterChain
,當(dāng)一個(gè)請(qǐng)求 HttpServletRequest 進(jìn)入 SecurityFilterChain
時(shí),會(huì)通過 matches
方法來(lái)確定是否滿足條件進(jìn)入過濾器鏈,進(jìn)而決定請(qǐng)求應(yīng)該執(zhí)行哪些過濾器。下面我們自己來(lái)梳理一遍。
請(qǐng)求執(zhí)行鏈路
我們以之前的文章為例,使用@Configuration
配置了一個(gè)SecurityFilterChain
Bean,能在Spring Boot 啟動(dòng)的時(shí)候創(chuàng)建SecurityFilterChain Bean到Sping。
@Configuration public class OAuth2LoginConfig @Bean public SecurityFilterChain filterChain(HttpSecurity http) throws Exception { http .authorizeHttpRequests(authorize -> authorize .anyRequest().authenticated() ) .oauth2Login(withDefaults()); return http.build(); }
這是官網(wǎng)的配置,說明任何請(qǐng)求都可以通過OAuth2來(lái)登錄。上面說過任何請(qǐng)求都會(huì)經(jīng)過SecurityFilterChain 的matches
方法,因此我們可以在SecurityFilterChain 的唯一實(shí)現(xiàn)類DefaultSecurityFilterChain
的matches
方法中打上斷點(diǎn)(圖1),這樣當(dāng)進(jìn)入斷點(diǎn)的時(shí)候,可以直觀的從IDE中看到調(diào)用棧
,這是調(diào)式源碼的時(shí)候一個(gè)非常有用的方法。
圖1
啟動(dòng)應(yīng)用,請(qǐng)求一個(gè)接口localhost:8080/hello,進(jìn)入端點(diǎn)后的調(diào)用棧如圖:
圖2
圖中箭頭所指的DelegatingFilterProxy
為Spring提供的一個(gè)標(biāo)準(zhǔn)的Servlet Filter代理,在xml的Spring時(shí)代,為了能使用Spring Security,需要在web.xml中添加該過濾器,而在Spring Boot中,Spring Boot的自動(dòng)配置已經(jīng)幫我們搞定,具體可見SecurityFilterAutoConfiguration
。
箭頭前面一部分是其他的幾個(gè)Servlet Filter,我們不做了解。
箭頭后面的部分,即DelegatingFilterProxy
之后,依次執(zhí)行了FilterChainProxy
和DefaultSecurityFilterChain
FilterChainProxy
是一個(gè)過濾器鏈代理類,內(nèi)部保存了過濾器鏈列表,而過濾器鏈內(nèi)部又具有各種過濾器
,如圖3。DefaultSecurityFilterChain
是SecurityFilterChain的默認(rèn)實(shí)現(xiàn)
到此為止,我們的第一個(gè)問題“請(qǐng)求執(zhí)行鏈路”基本已經(jīng)清晰了,即DelegatingFilterProxy >> FilterChainProxy >> SecurityFilterChain >> Filter
圖3
到此這篇關(guān)于Spring Security的過濾器鏈機(jī)制的文章就介紹到這了,更多相關(guān)Spring Security過濾器鏈內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java調(diào)用計(jì)算機(jī)攝像頭拍照實(shí)現(xiàn)過程解析
這篇文章主要介紹了Java調(diào)用計(jì)算機(jī)攝像頭拍照實(shí)現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05Mybatis?selectKey 如何返回新增用戶的id值
這篇文章主要介紹了Mybatis?selectKey 如何返回新增用戶的id值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01基于Ant路徑匹配規(guī)則AntPathMatcher的注意事項(xiàng)
這篇文章主要介紹了基于Ant路徑匹配規(guī)則AntPathMatcher的注意事項(xiàng),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11解決Jackson反序列化map,set等復(fù)雜類型問題
這篇文章主要介紹了解決Jackson反序列化map,set等復(fù)雜類型問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2020-09-09MyBatis多表關(guān)聯(lián)查詢的實(shí)現(xiàn)示例
本文主要介紹了MyBatis多表關(guān)聯(lián)查詢的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03java開源區(qū)塊鏈初始化創(chuàng)世區(qū)塊jdchain服務(wù)搭建
這篇文章主要介紹了java開源區(qū)塊鏈初始化創(chuàng)世區(qū)塊jdchain的服務(wù)搭建步驟,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-02-02