欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringSecurity如何設(shè)置白名單策略

 更新時(shí)間:2024年07月24日 10:05:32   作者:VermouthSp  
這篇文章主要介紹了SpringSecurity如何設(shè)置白名單策略,本文給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧

在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)合并單元格

    java使用EasyExcel實(shí)現(xiàn)合并單元格

    這篇文章主要為大家詳細(xì)介紹了java使用EasyExcel實(shí)現(xiàn)合并單元格的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-12-12
  • SpringBoot 如何整合 ES 實(shí)現(xiàn) CRUD 操作

    SpringBoot 如何整合 ES 實(shí)現(xiàn) CRUD 操作

    這篇文章主要介紹了SpringBoot 如何整合 ES 實(shí)現(xiàn) CRUD 操作,幫助大家更好的理解和使用springboot框架,感興趣的朋友可以了解下
    2020-10-10
  • springboot:接收date類型的參數(shù)方式

    springboot:接收date類型的參數(shù)方式

    這篇文章主要介紹了springboot:接收date類型的參數(shù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • Netty實(shí)現(xiàn)簡(jiǎn)易版的RPC框架過程詳解

    Netty實(shí)現(xiàn)簡(jiǎn)易版的RPC框架過程詳解

    這篇文章主要為大家介紹了Netty實(shí)現(xiàn)簡(jiǎn)易版的RPC框架過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • Java方法上注解值修改不成功的問題

    Java方法上注解值修改不成功的問題

    這篇文章主要介紹了Java方法上注解值修改不成功的解決方法,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-02-02
  • java向文件末尾添加內(nèi)容示例分享

    java向文件末尾添加內(nèi)容示例分享

    本文為大家提供一個(gè)java向文件末尾添加內(nèi)容的示例分享,大家參考使用吧
    2014-01-01
  • JDK13.0.1安裝與環(huán)境變量的配置教程圖文詳解(Win10平臺(tái)為例)

    JDK13.0.1安裝與環(huán)境變量的配置教程圖文詳解(Win10平臺(tái)為例)

    這篇文章主要介紹了JDK13.0.1安裝與環(huán)境變量的配置教程圖文詳解(Win10平臺(tái)為例),本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-01-01
  • Spring Cloud Feign統(tǒng)一設(shè)置驗(yàn)證token實(shí)現(xiàn)方法解析

    Spring 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-08
  • SpringBoot中集成Swagger2及簡(jiǎn)單實(shí)用

    SpringBoot中集成Swagger2及簡(jiǎn)單實(shí)用

    使用Swagger你只需要按照它的規(guī)范去定義接口及接口相關(guān)的信息,再通過Swagger衍生出來的一系列項(xiàng)目和工具,就可以做到生成各種格式的接口文檔,以及在線接口調(diào)試頁(yè)面等等,這篇文章主要介紹了SpringBoot中集成Swagger2,需要的朋友可以參考下
    2023-06-06
  • java中的Timer和Timertask的關(guān)系解讀

    java中的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è)TimerTask
    2024-12-12

最新評(píng)論