91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Spring Security如何構建rest服務實現rememberme記住我功能

發布時間:2021-07-10 10:46:16 來源:億速云 閱讀:121 作者:小新 欄目:編程語言

小編給大家分享一下Spring Security如何構建rest服務實現rememberme記住我功能,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

Spring security記住我基本原理:

登錄的時候,請求發送給過濾器UsernamePasswordAuthenticationFilter,當該過濾器認證成功后,會調用RememberMeService,會生成一個token,將token寫入到瀏覽器cookie,同時RememberMeService里邊還有個TokenRepository,將token和用戶信息寫入到數據庫中。這樣當用戶再次訪問系統,訪問某一個接口時,會經過一個RememberMeAuthenticationFilter的過濾器,他會讀取cookie中的token,交給RememberService,RememberService會用TokenRepository根據token從數據庫中查是否有記錄,如果有記錄會把用戶名取出來,再調用UserDetailService根據用戶名獲取用戶信息,然后放在SecurityContext里。

Spring Security如何構建rest服務實現rememberme記住我功能

 RememberMeAuthenticationFilter在Spring Security中認證過濾器鏈的倒數第二個過濾器位置,當其他認證過濾器都沒法認證成功的時候,就會調用RememberMeAuthenticationFilter嘗試認證。

Spring Security如何構建rest服務實現rememberme記住我功能

實現:

 1,登錄表單加上<input type="checkbox" name="remember-me" value="true"/>,SpringSecurity在SpringSessionRememberMeServices類里定義了一個常量,默認值就是remember-me

 2,根據上邊的原理圖可知,要配置TokenRepository,把生成的token存進數據庫,這是一個配置bean的配置,放在了BrowserSecurityConfig里

3,在configure里配置

4,在BrowserProperties里加上自動登錄時間,把記住我時間做成可配置的

//記住我秒數配置
private int rememberMeSeconds = 10;齊活
package com.imooc.s@Configuration //這是一個配置
public class BrowserSecurityConfig extends WebSecurityConfigurerAdapter{
  //讀取用戶配置的登錄頁配置
  @Autowired
  private SecurityProperties securityProperties;
  //自定義的登錄成功后的處理器
  @Autowired
  private AuthenticationSuccessHandler imoocAuthenticationSuccessHandler;
  //自定義的認證失敗后的處理器
  @Autowired
  private AuthenticationFailureHandler imoocAuthenticationFailureHandler;
  //數據源
  @Autowired
  private DataSource dataSource;
  @Autowired
  private UserDetailsService userDetailsService;
  //注意是org.springframework.security.crypto.password.PasswordEncoder
  @Bean
  public PasswordEncoder passwordencoder(){
    //BCryptPasswordEncoder implements PasswordEncoder
    return new BCryptPasswordEncoder();
  }
  /**
   * 記住我TokenRepository配置,在登錄成功后執行
   * 登錄成功后往數據庫存token的
   * @Description: 記住我TokenRepository配置
   * @param @return  JdbcTokenRepositoryImpl
   * @return PersistentTokenRepository 
   * @throws
   * @author lihaoyang
   * @date 2018年3月5日
   */
  @Bean
  public PersistentTokenRepository persistentTokenRepository(){
    JdbcTokenRepositoryImpl jdbcTokenRepository = new JdbcTokenRepositoryImpl();
    jdbcTokenRepository.setDataSource(dataSource);
    //啟動時自動生成相應表,可以在JdbcTokenRepositoryImpl里自己執行CREATE_TABLE_SQL腳本生成表
    jdbcTokenRepository.setCreateTableOnStartup(true);
    return jdbcTokenRepository;
  }
  //版本二:可配置的登錄頁
  @Override
  protected void configure(HttpSecurity http) throws Exception {
    //驗證碼過濾器
    ValidateCodeFilter validateCodeFilter = new ValidateCodeFilter();
    //驗證碼過濾器中使用自己的錯誤處理
    validateCodeFilter.setAuthenticationFailureHandler(imoocAuthenticationFailureHandler);
    //配置的驗證碼過濾url
    validateCodeFilter.setSecurityProperties(securityProperties);
    validateCodeFilter.afterPropertiesSet();
    //實現需要認證的接口跳轉表單登錄,安全=認證+授權
    //http.httpBasic() //這個就是默認的彈框認證
    //
    http //把驗證碼過濾器加載登錄過濾器前邊
      .addFilterBefore(validateCodeFilter, UsernamePasswordAuthenticationFilter.class)
      //表單認證相關配置
      .formLogin() 
        .loginPage("/authentication/require") //處理用戶認證BrowserSecurityController
        //登錄過濾器UsernamePasswordAuthenticationFilter默認登錄的url是"/login",在這能改
        .loginProcessingUrl("/authentication/form") 
        .successHandler(imoocAuthenticationSuccessHandler)//自定義的認證后處理器
        .failureHandler(imoocAuthenticationFailureHandler) //登錄失敗后的處理
      .and()
      //記住我相關配置  
      .rememberMe()
        .tokenRepository(persistentTokenRepository())//TokenRepository,登錄成功后往數據庫存token的
        .tokenValiditySeconds(securityProperties.getBrowser().getRememberMeSeconds())//記住我秒數
        .userDetailsService(userDetailsService) //記住我成功后,調用userDetailsService查詢用戶信息
      .and()
      //授權相關的配置 
      .authorizeRequests() 
        // /authentication/require:處理登錄,securityProperties.getBrowser().getLoginPage():用戶配置的登錄頁
        .antMatchers("/authentication/require",
        securityProperties.getBrowser().getLoginPage(),//放過登錄頁不過濾,否則報錯
        "/verifycode/image").permitAll() //驗證碼
        .anyRequest()    //任何請求
        .authenticated()  //都需要身份認證
      .and()
        .csrf().disable() //關閉csrf防護
      ;  
  }
}ecurity.browser;

其中由于要和數據庫打交道,所以需要注入一個數據源:application.properties

spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/imooc-demo
spring.datasource.username=root
spring.datasource.password=root

啟動應用,訪問 localhost:8080/user,需要登錄

Spring Security如何構建rest服務實現rememberme記住我功能

Spring Security如何構建rest服務實現rememberme記住我功能

登錄成功:

Spring Security如何構建rest服務實現rememberme記住我功能

數據庫:生成一個persistent_logins表,存進去了一條數據

Spring Security如何構建rest服務實現rememberme記住我功能

停止服務,從新啟動(注釋掉生成保存token表的jdbcTokenRepository.setCreateTableOnStartup(true);)因為我們的用戶登錄信息都存在了session中,所以重啟服務后,再訪問localhost:8080/user,本應該重新引導到登錄頁,但是由于配置了記住我,所以能夠直接訪問,拿到了接口數據

Spring Security如何構建rest服務實現rememberme記住我功能

請求頭:

Spring Security如何構建rest服務實現rememberme記住我功能

至此基本的rememberMe已做好

以上是“Spring Security如何構建rest服務實現rememberme記住我功能”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武功县| 古浪县| 衡南县| 大宁县| 盐城市| 雷州市| 赣榆县| 台安县| 泽库县| 苍溪县| 东台市| 维西| 丹阳市| 毕节市| 安图县| 吉隆县| 婺源县| 华阴市| 土默特左旗| 中牟县| 红河县| 高碑店市| 敦煌市| 沁水县| 高平市| 昌黎县| 阿城市| 漾濞| 巴楚县| 大竹县| 镇巴县| 无棣县| 吴川市| 龙海市| 文化| 庆阳市| 上蔡县| 襄城县| 裕民县| 宝清县| 措美县|