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

淺析Spring Security登錄驗(yàn)證流程源碼

 更新時(shí)間:2019年11月18日 08:25:13   作者:字母哥博客  
這篇文章主要介紹了Spring Security登錄驗(yàn)證流程源碼解析,本文結(jié)合源碼講解登錄驗(yàn)證流程,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

一、登錄認(rèn)證基于過(guò)濾器鏈

Spring Security的登錄驗(yàn)證流程核心就是過(guò)濾器鏈。當(dāng)一個(gè)請(qǐng)求到達(dá)時(shí)按照過(guò)濾器鏈的順序依次進(jìn)行處理,通過(guò)所有過(guò)濾器鏈的驗(yàn)證,就可以訪問(wèn)API接口了。

SpringSecurity提供了多種登錄認(rèn)證的方式,由多種Filter過(guò)濾器來(lái)實(shí)現(xiàn),比如:

  • BasicAuthenticationFilter實(shí)現(xiàn)的是HttpBasic模式的登錄認(rèn)證
  • UsernamePasswordAuthenticationFilter實(shí)現(xiàn)用戶名密碼的登錄認(rèn)證
  • RememberMeAuthenticationFilter實(shí)現(xiàn)登錄認(rèn)證的“記住我”的功能
  • SmsCodeAuthenticationFilter實(shí)現(xiàn)短信驗(yàn)證碼登錄認(rèn)證
  • SocialAuthenticationFilter實(shí)現(xiàn)社交媒體方式登錄認(rèn)證的處理
  • Oauth2AuthenticationProcessingFilter和Oauth2ClientAuthenticationProcessingFilter實(shí)現(xiàn)Oauth2的鑒權(quán)方式

根據(jù)我們不同的需求實(shí)現(xiàn)及配置,不同的Filter會(huì)被加載到應(yīng)用中。

二、結(jié)合源碼講解登錄驗(yàn)證流程

我們就以用戶名、密碼登錄方式為例講解一下Spring Security的登錄認(rèn)證流程。

2.1 UsernamePasswordAuthenticationFilter

該過(guò)濾器封裝用戶基本信息(用戶名、密碼),定義登錄表單數(shù)據(jù)接收相關(guān)的信息。如:

  • 默認(rèn)的表單用戶名密碼input框name是username、password
  • 默認(rèn)的處理登錄請(qǐng)求路徑是/login、使用POST方法


2.2 AbstractAuthenticationProcessingFilter的doFilter方法的驗(yàn)證過(guò)程

UsernamePasswordAuthenticationFilter繼承自抽象類AbstractAuthenticationProcessingFilter,該抽象類定義了驗(yàn)證成功與驗(yàn)證失敗的處理方法。

2.3 驗(yàn)證成功之后的Handler和驗(yàn)證失敗之后的handler

也就是說(shuō)當(dāng)我們需要自定義驗(yàn)證成功或失敗的處理方法時(shí),要去實(shí)現(xiàn)AuthenticationSuccessHandler或AuthenticationfailureHandler接口

三、登錄驗(yàn)證內(nèi)部細(xì)節(jié)

3.1多種認(rèn)證方式的管理 ProviderManager

ProviderManager用繼承于AuthenticationManager是登錄驗(yàn)證的核心類。ProviderManager保管了多個(gè)AuthenticationProvider,用于不同類型的登錄驗(yàn)證。比如:

  • RememberMeAuthenticationProvider定義了“記住我”功能的登錄驗(yàn)證邏輯
  • DaoAuthenticationProvider加載數(shù)據(jù)庫(kù)用戶信息,進(jìn)行用戶密碼的登錄驗(yàn)證

public class ProviderManager implements AuthenticationManager, MessageSourceAware, InitializingBean {
    ……
    private List<AuthenticationProvider> providers;
    ……

下文是ProviderManager的核心源碼,遍歷不同登錄驗(yàn)證的AuthenticationProvider,只有當(dāng)這種方式被支持的時(shí)候,才執(zhí)行具體的登錄驗(yàn)證邏輯。

3.2 登錄認(rèn)證接口 AuthenticationProvider

public interface AuthenticationProvider {
 Authentication authenticate(Authentication var1) throws AuthenticationException;
 boolean supports(Class<?> var1);
}

AuthenticationProvider的實(shí)現(xiàn)類定義了具體的登錄驗(yàn)證邏輯

3.3 數(shù)據(jù)庫(kù)加載用戶信息 DaoAuthenticationProvider

public class DaoAuthenticationProvider extends AbstractUserDetailsAuthenticationProvider {

從數(shù)據(jù)庫(kù)獲取用戶信息源碼

所以當(dāng)我們需要加載用戶信息進(jìn)行登錄驗(yàn)證的時(shí)候,我們需要實(shí)現(xiàn)UserDetailsService接口,重寫loadUserByUsername方法,參數(shù)是用戶輸入的用戶名。返回值是UserDetails。

總結(jié)

以上所述是小編給大家介紹的Spring Security登錄驗(yàn)證流程源碼,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!

相關(guān)文章

  • 如何在springboot中使用定時(shí)任務(wù)

    如何在springboot中使用定時(shí)任務(wù)

    這篇文章主要介紹了如何在springboot中使用定時(shí)任務(wù),幫助大家更好的理解和使用springboot框架,感興趣的朋友可以了解下
    2020-12-12
  • Spring中@PathVariable注解的簡(jiǎn)單使用

    Spring中@PathVariable注解的簡(jiǎn)單使用

    這篇文章主要介紹了Spring中@PathVariable注解的簡(jiǎn)單使用,@PathVariable 是 Spring Framework 中的注解之一,用于處理 RESTful Web 服務(wù)中的 URL 路徑參數(shù),它的作用是將 URL 中的路徑變量綁定到方法的參數(shù)上,需要的朋友可以參考下
    2024-01-01
  • 如何基于SpringMVC實(shí)現(xiàn)斷點(diǎn)續(xù)傳(HTTP)

    如何基于SpringMVC實(shí)現(xiàn)斷點(diǎn)續(xù)傳(HTTP)

    這篇文章主要介紹了如何基于SpringMVC實(shí)現(xiàn)斷點(diǎn)續(xù)傳(HTTP),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-01-01
  • Java實(shí)現(xiàn)可視化走迷宮小游戲的示例代碼

    Java實(shí)現(xiàn)可視化走迷宮小游戲的示例代碼

    這篇文章主要介紹了Java如何實(shí)現(xiàn)可視化走迷宮小游戲。本程序適用于java程序員鞏固類與對(duì)象、文件讀取、事件響應(yīng)、awt包中各種工具的相關(guān)概念以及對(duì)邏輯能力的鍛煉,需要的可以參考一下
    2022-11-11
  • Java棧的運(yùn)用之中綴表達(dá)式求值詳解

    Java棧的運(yùn)用之中綴表達(dá)式求值詳解

    本文來(lái)介紹一題中綴表達(dá)式求值的問(wèn)題,就是給定一個(gè)中綴計(jì)算式,編寫程序?qū)⑦@個(gè)式子運(yùn)算結(jié)果給計(jì)算出來(lái),其實(shí)和后綴表達(dá)式的思路差不多,都是棧的運(yùn)用問(wèn)題,感興趣的可以了解一下
    2022-11-11
  • Java數(shù)據(jù)脫敏常用方法(3種)

    Java數(shù)據(jù)脫敏常用方法(3種)

    數(shù)據(jù)脫敏常用在電話號(hào)碼和身份證號(hào),本文主要介紹了Java數(shù)據(jù)脫敏常用方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • Java I/O深入學(xué)習(xí)之File和RandomAccessFile

    Java I/O深入學(xué)習(xí)之File和RandomAccessFile

    這篇文章主要介紹了Java I/O深入學(xué)習(xí)之File和RandomAccessFile, I/O系統(tǒng)即輸入/輸出系統(tǒng),對(duì)于一門程序語(yǔ)言來(lái)說(shuō),創(chuàng)建一個(gè)好的輸入/輸出系統(tǒng)并非易事。在充分理解Java I/O系統(tǒng)以便正確地運(yùn)用之前,我們需要學(xué)習(xí)相當(dāng)數(shù)量的類。,需要的朋友可以參考下
    2019-06-06
  • 詳解SpringIOC容器相關(guān)知識(shí)

    詳解SpringIOC容器相關(guān)知識(shí)

    這篇文章主要記錄自己在狂神說(shuō)java中的學(xué)習(xí)情況,文章里有自己學(xué)習(xí)的理解和擴(kuò)展,新手難免有理解偏差或者錯(cuò)誤,懇請(qǐng)大佬指正下,需要的朋友可以參考下
    2021-05-05
  • Java基礎(chǔ)之練習(xí)打印三角形

    Java基礎(chǔ)之練習(xí)打印三角形

    這篇文章主要介紹了Java基礎(chǔ)之練習(xí)打印三角形,文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)java基礎(chǔ)的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • Java虛擬機(jī)啟動(dòng)過(guò)程探索

    Java虛擬機(jī)啟動(dòng)過(guò)程探索

    當(dāng)我們?cè)诰帉慗ava應(yīng)用的時(shí)候,很少會(huì)注意Java程序是如何被運(yùn)行的,如何被操作系統(tǒng)管理和調(diào)度的,帶著好奇心,探索一下Java虛擬機(jī)啟動(dòng)過(guò)程
    2022-05-05

最新評(píng)論