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

Spring Security驗證流程剖析及自定義驗證方法

 更新時間:2018年03月08日 16:53:19   作者:Beginner_H  
Spring Security是一個能夠為基于Spring的企業(yè)應(yīng)用系統(tǒng)提供聲明式的安全訪問控制解決方案的安全框架。這篇文章主要介紹了Spring Security驗證流程剖析及自定義驗證方法,需要的朋友可以參考下

Spring Security的本質(zhì)

Spring Security 本質(zhì)上是一連串的 Filter , 然后又以一個獨立的 Filter 的形式插入到 Filter Chain 里,其名為 FilterChainProxy 。 如圖所示。

 

實際上 FilterChainProxy 下面可以有多條 Filter Chain ,來針對不同的URL做驗證,而 Filter Chain 中所擁有的 Filter 則會根據(jù)定義的服務(wù)自動增減。所以無需要顯示再定義這些 Filter ,除非想要實現(xiàn)自己的邏輯。

 

關(guān)鍵類

Authentication

Authentication 是一個接口,用來表示用戶認(rèn)證信息,在用戶登錄認(rèn)證之前相關(guān)信息會封裝為一個 Authentication 具體實現(xiàn)類的對象,在登錄認(rèn)證成功之后又會生成一個信息更全面,包含用戶權(quán)限等信息的 Authentication 對象,然后把它保存在 SecurityContextHolder 所持有的 SecurityContext 中,供后續(xù)的程序進行調(diào)用,如訪問權(quán)限的鑒定等。

AuthenticationManager

用來做驗證的最主要的接口為 AuthenticationManager ,這個接口只有一個方法:

public interface AuthenticationManager {
 Authentication authenticate(Authentication authentication)
 throws AuthenticationException;
}

其中 authenticate() 方法運行后可能會有三種情況:

驗證成功,返回一個帶有用戶信息的 Authentication 。

驗證失敗,拋出一個 AuthenticationException 異常。

無法判斷,返回 null 。

ProviderManager

ProviderManager 是上面的 AuthenticationManager 最常見的實現(xiàn),它不自己處理驗證,而是將驗證委托給其所配置的 AuthenticationProvider 列表,然后會依次調(diào)用每一個 AuthenticationProvider 進行認(rèn)證,這個過程中只要有一個 AuthenticationProvider 驗證成功,就不會再繼續(xù)做更多驗證,會直接以該認(rèn)證結(jié)果作為 ProviderManager 的認(rèn)證結(jié)果。

 

認(rèn)證過程

用戶使用用戶名和密碼進行登錄。

Spring Security 將獲取到的用戶名和密碼封裝成一個 Authentication 接口的實現(xiàn)類,比如常用的 UsernamePasswordAuthenticationToken 。

將上述產(chǎn)生的 Authentication 對象傳遞給 AuthenticationManager 的實現(xiàn)類 ProviderManager 進行認(rèn)證。

ProviderManager 依次調(diào)用各個 AuthenticationProvider 進行認(rèn)證,認(rèn)證成功后返回一個封裝了用戶權(quán)限等信息的 Authentication 對象。

將 AuthenticationManager 返回的 Authentication 對象賦予給當(dāng)前的 SecurityContext 。

自定義驗證

有了以上的知識儲備后就可以來自定義驗證方法了。通過上面可以看出,實際上真正來做驗證操作的是一個個的 AuthenticationProvider ,所以如果要自定義驗證方法,只需要實現(xiàn)一個自己的 AuthenticationProvider 然后再將其添加進 ProviderManager 里就行了。

自定義AuthenticationProvider

@Component
public class CustomAuthenticationProvider
 implements AuthenticationProvider {
 @Override
 public Authentication authenticate(Authentication authentication) 
 throws AuthenticationException {
 String name = authentication.getName();
 String password = authentication.getCredentials().toString();
 if (shouldAuthenticateAgainstThirdPartySystem()) {
  // use the credentials
  // and authenticate against the third-party system
  return new UsernamePasswordAuthenticationToken(
  name, password, new ArrayList<>());
 } else {
  return null;
 }
 }
 @Override
 public boolean supports(Class<?> authentication) {
 return authentication.equals(
  UsernamePasswordAuthenticationToken.class);
 }
}

其中的 supports() 方法接受一個 authentication 參數(shù),用來判斷傳進來的 authentication 是不是該 AuthenticationProvider 能夠處理的類型。

注冊AuthenticationProvider

現(xiàn)在再將剛創(chuàng)建的 AuthenticationProvider 在 與ProviderManager 里注冊,所有操作就完成了。

@Configuration
@EnableWebSecurity
@ComponentScan("org.baeldung.security")
public class SecurityConfig extends WebSecurityConfigurerAdapter {
 @Autowired
 private CustomAuthenticationProvider authProvider;
 @Override
 protected void configure(
 AuthenticationManagerBuilder auth) throws Exception {
 auth.authenticationProvider(authProvider);
 }
 @Override
 protected void configure(HttpSecurity http) throws Exception {
 http.authorizeRequests().anyRequest().authenticated()
  .and()
  .httpBasic();
 }
}

總結(jié)

以上所述是小編給大家介紹的Spring Security驗證流程剖析及自定義驗證方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Springboot如何使用Aspectj實現(xiàn)AOP面向切面編程

    Springboot如何使用Aspectj實現(xiàn)AOP面向切面編程

    這篇文章主要介紹了Springboot如何使用Aspectj實現(xiàn)AOP面向切面編程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • 詳解java.lang.reflect.Modifier.isInterface()方法

    詳解java.lang.reflect.Modifier.isInterface()方法

    這篇文章主要介紹了詳解java.lang.reflect.Modifier.isInterface()方法的相關(guān)資料,這里提供實例幫助大家理解這個方法的使用,需要的朋友可以參考下
    2017-09-09
  • Java創(chuàng)建二叉搜索樹,實現(xiàn)搜索,插入,刪除的操作實例

    Java創(chuàng)建二叉搜索樹,實現(xiàn)搜索,插入,刪除的操作實例

    下面小編就為大家分享一篇Java創(chuàng)建二叉搜索樹,實現(xiàn)搜索,插入,刪除的操作實例,具有很好的參考價值,希望對大家有所幫助
    2017-12-12
  • Java中利用BitMap位圖實現(xiàn)海量級數(shù)據(jù)去重

    Java中利用BitMap位圖實現(xiàn)海量級數(shù)據(jù)去重

    有許多方法可以用來去重,比如使用列表、集合等等,但這些方法通常只適用于一般情況,然而,當(dāng)涉及到大量數(shù)據(jù)去重時,常見的 Java Set、List,甚至是 Java 8 的新特性 Stream 流等方式就顯得不太合適了,本文給大家介紹了Java中利用BitMap位圖實現(xiàn)海量級數(shù)據(jù)去重
    2024-04-04
  • SpringBoot整合阿里云短信服務(wù)的案例代碼

    SpringBoot整合阿里云短信服務(wù)的案例代碼

    這篇文章主要介紹了SpringBoot整合阿里云短信服務(wù)的案例代碼,在Spring Boot項目的pom.xml文件中添加阿里云短信服務(wù)SDK的依賴,本文通過示例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2024-06-06
  • 基于Java編寫一個粽子大作戰(zhàn)小游戲

    基于Java編寫一個粽子大作戰(zhàn)小游戲

    端午節(jié),又稱龍舟節(jié)、重午節(jié),是中國的傳統(tǒng)節(jié)日之一,每年農(nóng)歷五月初五慶祝,雖然端午假期已經(jīng)過去了,小編還是用Java編寫了一個粽子大作戰(zhàn)小游戲,感興趣的可以了解一下
    2023-06-06
  • Java實戰(zhàn)之藥品管理系統(tǒng)的實現(xiàn)

    Java實戰(zhàn)之藥品管理系統(tǒng)的實現(xiàn)

    這篇文章主要介紹了利用Java實現(xiàn)的藥品管理系統(tǒng),本項目屬于前后端分離的項目,分為兩個角色藥品管理員和取藥處人員,感興趣的小伙伴可以學(xué)習(xí)一下
    2022-04-04
  • JDK9為何要將String的底層實現(xiàn)由char[]改成了byte[]

    JDK9為何要將String的底層實現(xiàn)由char[]改成了byte[]

    String 類的源碼已經(jīng)由?char[]?優(yōu)化為了?byte[]?來存儲字符串內(nèi)容,為什么要這樣做呢?本文就詳細(xì)的介紹一下,感興趣的可以了解一下
    2022-03-03
  • Java集合功能與用法實例詳解

    Java集合功能與用法實例詳解

    這篇文章主要介紹了Java集合功能與用法,結(jié)合實例形式詳細(xì)分析了java集合的基本概念、功能、原理、操作技巧與使用注意事項,需要的朋友可以參考下
    2020-04-04
  • Java servlet通過事件驅(qū)動進行高性能長輪詢詳解

    Java servlet通過事件驅(qū)動進行高性能長輪詢詳解

    這篇文章主要介紹了基于servlet3.0+事件驅(qū)動實現(xiàn)高性能長輪詢的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2022-06-06

最新評論