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

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

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

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

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

SpringSecurity提供了多種登錄認(rèn)證的方式,由多種Filter過濾器來實(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

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

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


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

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

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

也就是說當(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ù)庫用戶信息,進(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ù)庫加載用戶信息 DaoAuthenticationProvider

public class DaoAuthenticationProvider extends AbstractUserDetailsAuthenticationProvider {

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

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

總結(jié)

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

相關(guān)文章

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

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

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

    Spring中@PathVariable注解的簡單使用

    這篇文章主要介紹了Spring中@PathVariable注解的簡單使用,@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),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-01-01
  • Java實(shí)現(xiàn)可視化走迷宮小游戲的示例代碼

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

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

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

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

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

    數(shù)據(jù)脫敏常用在電話號碼和身份證號,本文主要介紹了Java數(shù)據(jù)脫敏常用方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(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),對于一門程序語言來說,創(chuàng)建一個(gè)好的輸入/輸出系統(tǒng)并非易事。在充分理解Java I/O系統(tǒng)以便正確地運(yùn)用之前,我們需要學(xué)習(xí)相當(dāng)數(shù)量的類。,需要的朋友可以參考下
    2019-06-06
  • 詳解SpringIOC容器相關(guān)知識

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

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

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

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

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

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

最新評論