久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Spring Security中的Servlet過(guò)濾器體系代碼分析

瀏覽:123日期:2023-08-29 11:20:29

1. 前言

我在Spring Security 實(shí)戰(zhàn)干貨:內(nèi)置 Filter 全解析對(duì)Spring Security的內(nèi)置過(guò)濾器進(jìn)行了羅列,但是Spring Security真正的過(guò)濾器體系才是我們了解它是如何進(jìn)行'認(rèn)證'、“授權(quán)”、“防止利用漏洞”的關(guān)鍵。

2. Servlet Filter體系

這里我們以Servlet Web為討論目標(biāo),Reactive Web暫不討論。我們先來(lái)看下最基礎(chǔ)的Servlet體系,在Servlet體系中客戶端發(fā)起一個(gè)請(qǐng)求過(guò)程是經(jīng)過(guò)0到N個(gè)Filter然后交給Servlet處理。

Spring Security中的Servlet過(guò)濾器體系代碼分析

Filter不但可以修改HttpServletRequest和HttpServletResponse,可以讓我們?cè)谡?qǐng)求響應(yīng)的前后做一些事情,甚至可以終止過(guò)濾器鏈FilterChain的傳遞。

public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) { // 請(qǐng)求被servlet 處理前 if(condition){ // 根據(jù)條件來(lái)進(jìn)入下一個(gè)過(guò)濾器 chain.doFilter(request, response); } // 請(qǐng)求被執(zhí)行完畢后處理一些事情 }

由于Filter僅影響下游Filters和Servlet,因此每個(gè)Filter調(diào)用的順序非常重要。Spring Security正是根據(jù)這個(gè)個(gè)特性來(lái)實(shí)現(xiàn)一系列的安全功能。接下來(lái)我們來(lái)看看它們是如何結(jié)合的。

3. GenericFilterBean

在該系列的文章開篇我對(duì)Spring Security和Shiro進(jìn)行了簡(jiǎn)單的對(duì)比。Spring Security利用了Spring IOC和AOP的特性而無(wú)法脫離Spring獨(dú)立存在,而Apache Shiro可以獨(dú)立存在。所以今天我們要一探究竟,看看他們是如何結(jié)合的。

Spring結(jié)合Servlet Filter自然是要為Servlet Filter注入Spring Bean的特性,所以就搞出了一個(gè)抽象Filter Bean,這個(gè)抽象過(guò)濾器GenericFilterBean并不是在Spring Security下,而是Spring Web體系中,類圖如下:

Spring Security中的Servlet過(guò)濾器體系代碼分析

從類圖上看Filter接口已經(jīng)被注入了多個(gè)Spring Bean的特性,納入了Spring Bean生命周期,使得Spring IoC容器能夠充分的管理Filter。

4. DelegatingFilterProxy

我們希望Servlet能夠按照它自己的標(biāo)準(zhǔn)來(lái)注冊(cè)到過(guò)濾器鏈中工作,但是同時(shí)也希望它能夠被Spring IoC管理,所以Spring提供了一個(gè)GenericFilterBean的實(shí)現(xiàn)DelegatingFilterProxy。我們可以將原生的Servlet Filter或者Spring Bean Filter委托給DelegatingFilterProxy,然后在結(jié)合到Servlet FilterChain中。

Spring Security中的Servlet過(guò)濾器體系代碼分析

5. SecurityFilterChain

針對(duì)不同符合Ant Pattern的請(qǐng)求可能會(huì)走不同的過(guò)濾器鏈,比如登錄會(huì)去驗(yàn)證,然后返回登錄結(jié)果;管理后臺(tái)的接口走后臺(tái)的安全邏輯,應(yīng)用客戶端的接口走客戶端的安全邏輯。Spring Security提供了一個(gè)SecurityFilterChain接口來(lái)滿足被匹配HttpServletRequest走特定的過(guò)濾器鏈的需求。

public interface SecurityFilterChain { // 判斷請(qǐng)求 是否符合該過(guò)濾器鏈的要求 boolean matches(HttpServletRequest request); // 對(duì)應(yīng)的過(guò)濾器鏈 List<Filter> getFilters();}

Spring Security中的Servlet過(guò)濾器體系代碼分析

6. FilterChainProxy

不同的SecurityFilterChain應(yīng)該是互斥而且平等的,它們之間不應(yīng)該是上下游關(guān)系。

Spring Security中的Servlet過(guò)濾器體系代碼分析

如上圖請(qǐng)求被匹配到不同的SecurityFilterChain然后在執(zhí)行剩余的過(guò)濾器鏈。它們經(jīng)過(guò)SecurityFilterChain的總流程是相似的,而且有些時(shí)候特定的一些SecurityFilterChain也需要被集中管理來(lái)實(shí)現(xiàn)特定一攬子的請(qǐng)求的過(guò)濾邏輯。所以就有了另外一個(gè)GenericFilterBean實(shí)現(xiàn)來(lái)做這個(gè)事情,它就是FilterChainProxy。它的作用就是攔截符合條件的請(qǐng)求,然后根據(jù)請(qǐng)求篩選出符合要求的SecurityFilterChain,然后鏈?zhǔn)降膱?zhí)行這些Filter,最后繼續(xù)執(zhí)行剩下的FilterChain。

擴(kuò)展閱讀:Spring Security 過(guò)濾器鏈

7. 總結(jié)

結(jié)合上面,最終上述這些概念的關(guān)系徹底搞清楚了,搞清楚過(guò)濾器的運(yùn)作模式對(duì)于學(xué)習(xí)和使用Spring Security至關(guān)重要。

Spring Security中的Servlet過(guò)濾器體系代碼分析

到此這篇關(guān)于Spring Security中的Servlet過(guò)濾器體系的文章就介紹到這了,更多相關(guān)Spring Security Servlet過(guò)濾器體系內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 黄色国产大片 | 亚洲精品视频大全 | 天天干天天干天天干天天射 | 婷婷色国产偷v国产偷v小说 | 国产精品久久久久久久久久久免费看 | 色婷婷在线视频观看 | 蜜桃视频一区二区三区 | 91精品中文字幕一区二区三区 | 欧美精品亚洲精品日韩精品 | 精品视频一区二区三区四区 | 亚洲美女在线视频 | 欧美成人资源 | 最近免费中文字幕在线视频2 | 大黄网站在线观看 | av一道本| 国产精选一区二区三区不卡催乳 | www国产亚洲精品久久网站 | 中文字幕日韩欧美一区二区三区 | 亚洲一区二区三区免费在线观看 | 精品国产99 | 在线观看中文字幕 | 毛片国产| 亚洲成人精品久久久 | 欧美中文一区 | 蜜桃官网 | 久久久com| 日韩亚洲视频在线观看 | 久久国产区 | 国内精品一区二区三区 | 91在线免费看| 日韩精品一区二区三区在线 | 一级片欧美 | 亚洲一区二区三 | 91久久久久久久 | 精品一区二区在线观看 | 国产成人精品免费 | 日韩欧美网址 | 99久久精品免费看国产一区二区三区 | 手机看片169| 日韩午夜影院 | 久久久午夜爽爽一区二区三区三州 |