全面解析Spring Security 過濾器鏈的機(jī)制和特性
1. 前言
過濾器作為 Spring Security 的重中之重,我們需要了解其中的機(jī)制。這樣我們才能根據(jù)業(yè)務(wù)需求的變化進(jìn)行定制。今天來探討一下 Spring Security 中的過濾器鏈機(jī)制。
2. Spring Security 過濾器鏈
客戶端(APP 和后臺管理客戶端)向應(yīng)用程序發(fā)送請求,然后應(yīng)用根據(jù)請求的 URI 的路徑來確定該請求的過濾器鏈(Filter)以及最終的具體 Servlet 控制器(Controller)。
從上圖我們可以看出 Spring Security 以一個單 Filter(FilterChainProxy) 存在于整個過濾器鏈中,而這個 FilterChainProxy 實(shí)際內(nèi)部代理著眾多的 Spring Security Filter 。這簡直就是套娃啊!
2.1 過濾器鏈的形成過程
再多說一點(diǎn) Filter 們的初始化過程,首先 Filter 們按照一定的順序被 SecurityBuilder 的實(shí)現(xiàn)來組裝為 SecurityFilterChain ,然后通過 WebSecurity 注入到 FilterChainProxy 中去,接著 FilterChainProxy 又在 WebSecurityConfiguration 中以 springSecurityFilterChain 的名稱注冊為 Spring Bean 。實(shí)際上還有一個隱藏層 DelegatingFilterProxy 代理了 springSecurityFilterChain 注入到最后整個 Servlet 過濾器鏈中。簡單畫了個圖;
事實(shí)上 Spring Security 的內(nèi)置 Filter 對于 Spring IoC 容器來說都是不可見的。
”Spring Security 允許有多 條過濾器鏈并行,Spring Security 的 FilterChainProxy 可以代理多條過濾器鏈并根據(jù)不同的 URI 匹配策略進(jìn)行分發(fā)。但是每個請求每次只能被分發(fā)到一條過濾器鏈。如下圖所示:
關(guān)于 Filter 的其它細(xì)節(jié)可以通過 相關(guān)文章[1] 了解。
★實(shí)際每條過濾鏈 就是一個 SecurityFilterChain
”4. 總結(jié)
今天我們通過對 Spring Security 中 過濾器鏈機(jī)制,對于深入學(xué)習(xí) Spring Security 有著至關(guān)重要的意義。有什么問題和心得請留言反饋。
參考資料
相關(guān)文章: https://www.felord.cn/spring-security-filters.html
到此這篇關(guān)于Spring Security 過濾器鏈的機(jī)制和特性的文章就介紹到這了,更多相關(guān)Spring Security 過濾器鏈內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 在Android中使用WebSocket實(shí)現(xiàn)消息通信的方法詳解2. 淺談python出錯時traceback的解讀3. Python importlib動態(tài)導(dǎo)入模塊實(shí)現(xiàn)代碼4. python matplotlib:plt.scatter() 大小和顏色參數(shù)詳解5. windows服務(wù)器使用IIS時thinkphp搜索中文無效問題6. ASP 信息提示函數(shù)并作返回或者轉(zhuǎn)向7. Nginx+php配置文件及原理解析8. 利用promise及參數(shù)解構(gòu)封裝ajax請求的方法9. .NET中l(wèi)ambda表達(dá)式合并問題及解決方法10. JSP數(shù)據(jù)交互實(shí)現(xiàn)過程解析
