成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Spring Security功能實現及源碼分析

開發 前端
本篇給大家介紹Spring Security功能實現及源碼分析的相關知識,希望能夠幫助到你!

[[396412]]

環境:Spring Boot 2.2.11.RELEASE

請先閱讀《Spring Boot Security防重登錄及在線總數 》,《Springboot Security 基礎應用 (1) 》

相關配置

  • Security配置
  1. @Resource 
  2. private DataSource dataSource ; 
  3.  
  4. // 這里配置持久化登錄token 
  5. @Bean 
  6. public PersistentTokenRepository persistentTokenRepository() { 
  7.     JdbcTokenRepositoryImpl tokenRepository = new JdbcTokenRepositoryImpl(); 
  8.   tokenRepository.setDataSource(dataSource) ; 
  9.   return tokenRepository; 
  •  SQL腳本

進入JdbcTokenRepositoryImpl中將其中的CREATE_TABLE_SQL語句復制出來執行下。

  • HttpSecurity配置
  1. http.rememberMe() 
  2.             .tokenRepository(persistentTokenRepository()) 
  3.             .userDetailsService(userDetailsService()) // 記住我功能有效期內,用來查詢用戶詳細信息的UserDetailsService 
  4.             .tokenValiditySeconds(1800) ; // token有效期 

 登錄頁面

  1. <div class="c-row" style="height: auto;"
  2.   <input type="checkbox" class="checkbox-control" id="remember-me" name="remember-me"/><label for="remember-me">記住我</label> 
  3. </div> 

 注意這里的checkbox的name屬性值必須是“remember-me”。

這樣就可以實現記住我功能了。只要在token有效期內,每次打開頁面都不需要重新登錄了。

  • 測試

登錄后,關閉瀏覽器重寫再打開頁面不需要重新登錄,同時查看數據表如下:

源碼分析

我們從第一次登錄開始

1.1 首先進入的

UsernamePasswordAuthenticationFilter過濾器,進入父類(AbstractAuthenticationProcessingFilter)的doFilter方法中。

直接進入登錄成功的方法

1.2 執行successfulAuthentication方法

  1. successfulAuthentication(request, response, chain, authResult); 

 

1.3 進入loginSuccess方法

進入

AbstractRememberMeServices類中的loginSuccess方法

1.4 執行子類

PersistentTokenBasedRememberMeServices中的onLoginSuccess方法。

這里的tokenRepository就是我們上面配置的

接著我們看再次打開瀏覽器后是如何實現免登錄的。

1.1 首先執行

RememberMeAuthenticationFilter的doFilter方法

這個過濾器是只有你開啟了記住我功能才會生效的。

從當前Security上下文中獲取對象,獲取不到通過remeberMeService自動登錄

1.2 執行

AbstractRememberMeServices中的autoLogin方法

執行extractRememberMeCookie方法獲取cookie中的remember-me信息

1.3 執行processAutoLoginCookie方法

這里解析出來的信息已經和數據庫中對應上了。這樣就可以拿到username了。

1.4 接下來執行一些判斷token是否過期和更新token有效期

驗證是否過期

更新token有效期

1.5 根據查詢出來的username查詢用戶信息

  1. return getUserDetailsService().loadUserByUsername(token.getUsername()); 

1.6 最后將用戶信息存儲到Security的上下文中

完畢!!!

 

責任編輯:姜華 來源: 今日頭條
相關推薦

2021-06-07 14:06:19

Spring SecuCSRF防御

2022-06-16 10:38:24

URL權限源代碼

2024-01-29 08:28:01

Spring事務失效

2022-03-07 10:05:02

SpringStreamMQ連接

2024-01-05 08:38:20

SpringBeanScope

2021-08-09 11:15:28

MybatisJavaSpring

2023-11-09 09:08:38

RibbonSpring

2014-12-11 13:37:13

WPF架構

2021-04-26 08:54:17

Spring BootSecurity防重登錄

2021-12-28 11:13:05

安全認證 Spring Boot

2021-08-05 10:40:37

加密方案Spring

2012-02-23 12:53:40

JavaPlay Framew

2021-07-03 15:22:02

Mybatis InsID源碼

2023-01-10 07:52:15

2021-08-29 18:36:57

項目

2021-04-23 07:33:10

SpringSecurity單元

2023-08-26 19:04:40

配置write轉換器

2025-04-11 08:42:37

JavaScript倒計時前端

2011-04-26 09:33:04

SpringAOP

2020-10-09 14:13:04

Zookeeper Z
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲成av片人久久久 | 操操操av | 色婷婷国产精品综合在线观看 | 国产91色在线 | 亚洲 | 波多野结衣av中文字幕 | 国户精品久久久久久久久久久不卡 | 在线中文字幕视频 | 99精品欧美一区二区三区综合在线 | 久久99国产精品 | 91大神在线资源观看无广告 | 久久久91精品国产一区二区三区 | 国产视频精品免费 | 亚洲欧美一区二区三区视频 | 色综合视频 | 伊人久久一区二区 | 国产精品一区久久久久 | 性一交一乱一透一a级 | 成人精品一区二区三区 | 久久夜视频 | 亚洲精品在线免费播放 | 福利一区视频 | 日本aaaa| 国产精品3区 | 蜜桃视频成人 | 欧美精品中文字幕久久二区 | 黄色毛片网站在线观看 | 日日摸夜夜爽人人添av | 久久综合久久综合久久 | 欧美在线| 久久综合九色综合欧美狠狠 | 亚洲成av人影片在线观看 | 欧美日韩亚洲国产 | 天天天天操 | 蜜桃av一区二区三区 | 欧美性一区二区三区 | 91国语清晰打电话对白 | 日韩毛片网 | 一久久久 | 精品欧美乱码久久久久久1区2区 | 日本精品一区二区三区四区 | 欧美一区二区视频 |