SpringSecurity如何設(shè)置白名單策略
在SpringSecurity中,往往需要對(duì)部分接口白名單訪問,而大部分在使用Security中就有一個(gè)誤區(qū),那就是免鑒權(quán)訪問和白名單的區(qū)別。
大部分的Security文章包括官方文檔給出免鑒權(quán)訪問都是使用.permitAll()去對(duì)相應(yīng)路徑進(jìn)行免鑒權(quán)訪問,但實(shí)際上這僅僅只表示該資源不需要相應(yīng)的權(quán)限訪問,但是用戶還需要認(rèn)證.也就是Security的認(rèn)證/授權(quán)兩個(gè)概念.
Security白名單策略
將需要放行的白名單使用.ignoring注冊(cè).
@Bean public WebSecurityCustomizer ignoringCustomizer() { return web -> web.ignoring().requestMatchers(whiteUrlArr); }
當(dāng)Spring啟動(dòng)后,會(huì)將其中每個(gè)url注冊(cè)為一個(gè)MvcRequestMatcher并且放入到WebSecurity中的ignoredRequests管理。
然后在構(gòu)建WebSecurity時(shí)去創(chuàng)建對(duì)應(yīng)的DefaultSecurityFilterChain.
然后這些會(huì)被放入到Security的過濾鏈中交給WebSecurity進(jìn)行管理,當(dāng)有請(qǐng)求進(jìn)入后就會(huì)進(jìn)入到過濾鏈時(shí),WebSecurity會(huì)去循環(huán)調(diào)用chian,以獲取處理請(qǐng)求路徑對(duì)應(yīng)的過濾器組成過濾鏈,如果未注冊(cè)ignor則會(huì)使用默認(rèn)的AnyRequest,這將返回全部的Security過濾器.
private List<Filter> getFilters(HttpServletRequest request) { int count = 0; Iterator var3 = this.filterChains.iterator(); SecurityFilterChain chain; do { if (!var3.hasNext()) { return null; } chain = (SecurityFilterChain)var3.next(); if (logger.isTraceEnabled()) { ++count; logger.trace(LogMessage.format("Trying to match request against %s (%d/%d)", chain, count, this.filterChains.size())); } } while(!chain.matches(request)); return chain.getFilters(); }
而DefaultSecurityChain則會(huì)使用其對(duì)應(yīng)的match對(duì)請(qǐng)求路徑進(jìn)行匹配,如果匹配上則返回相應(yīng)的過濾器.
匹配成功返回RequestMatchResult:
通過返回的對(duì)象是否為空進(jìn)行判斷是否匹配成功:
匹配成功后會(huì)返回其對(duì)應(yīng)的Filter,因?yàn)槭峭ㄟ^igonr去進(jìn)行忽略的所以filter為空,所以就會(huì)忽略對(duì)對(duì)應(yīng)路徑請(qǐng)求的鑒權(quán)等操作.
這就是SpringSecurity真正的白名單,而不僅僅是對(duì)相應(yīng)路徑進(jìn)行免權(quán)訪問.
后續(xù)會(huì)嘗試去探索免權(quán)訪問...
到此這篇關(guān)于SpringSecurity如何正確的設(shè)置白名單的文章就介紹到這了,更多相關(guān)SpringSecurity白名單內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java使用EasyExcel實(shí)現(xiàn)合并單元格
這篇文章主要為大家詳細(xì)介紹了java使用EasyExcel實(shí)現(xiàn)合并單元格的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12SpringBoot 如何整合 ES 實(shí)現(xiàn) CRUD 操作
這篇文章主要介紹了SpringBoot 如何整合 ES 實(shí)現(xiàn) CRUD 操作,幫助大家更好的理解和使用springboot框架,感興趣的朋友可以了解下2020-10-10Netty實(shí)現(xiàn)簡(jiǎn)易版的RPC框架過程詳解
這篇文章主要為大家介紹了Netty實(shí)現(xiàn)簡(jiǎn)易版的RPC框架過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02JDK13.0.1安裝與環(huán)境變量的配置教程圖文詳解(Win10平臺(tái)為例)
這篇文章主要介紹了JDK13.0.1安裝與環(huán)境變量的配置教程圖文詳解(Win10平臺(tái)為例),本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-01-01Spring Cloud Feign統(tǒng)一設(shè)置驗(yàn)證token實(shí)現(xiàn)方法解析
這篇文章主要介紹了Spring Cloud Feign統(tǒng)一設(shè)置驗(yàn)證token實(shí)現(xiàn)方法解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08SpringBoot中集成Swagger2及簡(jiǎn)單實(shí)用
使用Swagger你只需要按照它的規(guī)范去定義接口及接口相關(guān)的信息,再通過Swagger衍生出來的一系列項(xiàng)目和工具,就可以做到生成各種格式的接口文檔,以及在線接口調(diào)試頁(yè)面等等,這篇文章主要介紹了SpringBoot中集成Swagger2,需要的朋友可以參考下2023-06-06java中的Timer和Timertask的關(guān)系解讀
本文詳細(xì)介紹了Java中的Timer和TimerTask類,包括它們之間的關(guān)系、API的使用方法、注意事項(xiàng)以及操作案例,Timer是一個(gè)調(diào)度器,而TimerTask是具體的任務(wù)類,Timer僅對(duì)應(yīng)一個(gè)線程,不保證任務(wù)執(zhí)行的精確性,但線程安全,一個(gè)Timer可以調(diào)度多個(gè)TimerTask2024-12-12