SpringSecurity如何設(shè)置白名單策略
在SpringSecurity中,往往需要對部分接口白名單訪問,而大部分在使用Security中就有一個誤區(qū),那就是免鑒權(quán)訪問和白名單的區(qū)別。
大部分的Security文章包括官方文檔給出免鑒權(quán)訪問都是使用.permitAll()去對相應(yīng)路徑進(jìn)行免鑒權(quán)訪問,但實(shí)際上這僅僅只表示該資源不需要相應(yīng)的權(quán)限訪問,但是用戶還需要認(rèn)證.也就是Security的認(rèn)證/授權(quán)兩個概念.
Security白名單策略
將需要放行的白名單使用.ignoring注冊.
@Bean
public WebSecurityCustomizer ignoringCustomizer() {
return web -> web.ignoring().requestMatchers(whiteUrlArr);
}當(dāng)Spring啟動后,會將其中每個url注冊為一個MvcRequestMatcher并且放入到WebSecurity中的ignoredRequests管理。

然后在構(gòu)建WebSecurity時去創(chuàng)建對應(yīng)的DefaultSecurityFilterChain.

然后這些會被放入到Security的過濾鏈中交給WebSecurity進(jìn)行管理,當(dāng)有請求進(jìn)入后就會進(jìn)入到過濾鏈時,WebSecurity會去循環(huán)調(diào)用chian,以獲取處理請求路徑對應(yīng)的過濾器組成過濾鏈,如果未注冊ignor則會使用默認(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則會使用其對應(yīng)的match對請求路徑進(jìn)行匹配,如果匹配上則返回相應(yīng)的過濾器.
匹配成功返回RequestMatchResult:

通過返回的對象是否為空進(jìn)行判斷是否匹配成功:

匹配成功后會返回其對應(yīng)的Filter,因為是通過igonr去進(jìn)行忽略的所以filter為空,所以就會忽略對對應(yīng)路徑請求的鑒權(quán)等操作.

這就是SpringSecurity真正的白名單,而不僅僅是對相應(yīng)路徑進(jìn)行免權(quán)訪問.
后續(xù)會嘗試去探索免權(quán)訪問...
到此這篇關(guān)于SpringSecurity如何正確的設(shè)置白名單的文章就介紹到這了,更多相關(guān)SpringSecurity白名單內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java使用EasyExcel實(shí)現(xiàn)合并單元格
這篇文章主要為大家詳細(xì)介紹了java使用EasyExcel實(shí)現(xiàn)合并單元格的相關(guān)知識,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12
SpringBoot 如何整合 ES 實(shí)現(xiàn) CRUD 操作
這篇文章主要介紹了SpringBoot 如何整合 ES 實(shí)現(xiàn) CRUD 操作,幫助大家更好的理解和使用springboot框架,感興趣的朋友可以了解下2020-10-10
Netty實(shí)現(xiàn)簡易版的RPC框架過程詳解
這篇文章主要為大家介紹了Netty實(shí)現(xiàn)簡易版的RPC框架過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02
JDK13.0.1安裝與環(huán)境變量的配置教程圖文詳解(Win10平臺為例)
這篇文章主要介紹了JDK13.0.1安裝與環(huán)境變量的配置教程圖文詳解(Win10平臺為例),本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2020-01-01
Spring Cloud Feign統(tǒng)一設(shè)置驗證token實(shí)現(xiàn)方法解析
這篇文章主要介紹了Spring Cloud Feign統(tǒng)一設(shè)置驗證token實(shí)現(xiàn)方法解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-08-08
SpringBoot中集成Swagger2及簡單實(shí)用
使用Swagger你只需要按照它的規(guī)范去定義接口及接口相關(guān)的信息,再通過Swagger衍生出來的一系列項目和工具,就可以做到生成各種格式的接口文檔,以及在線接口調(diào)試頁面等等,這篇文章主要介紹了SpringBoot中集成Swagger2,需要的朋友可以參考下2023-06-06
java中的Timer和Timertask的關(guān)系解讀
本文詳細(xì)介紹了Java中的Timer和TimerTask類,包括它們之間的關(guān)系、API的使用方法、注意事項以及操作案例,Timer是一個調(diào)度器,而TimerTask是具體的任務(wù)類,Timer僅對應(yīng)一個線程,不保證任務(wù)執(zhí)行的精確性,但線程安全,一個Timer可以調(diào)度多個TimerTask2024-12-12

