亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Spring Security 構(gòu)建rest服務(wù)實現(xiàn)rememberme 記住我功能

 更新時間:2018年03月06日 09:54:19   作者:奮斗的羊仔  
這篇文章主要介紹了Spring Security 構(gòu)建rest服務(wù)實現(xiàn)rememberme 記住我功能,需要的朋友可以參考下

Spring security記住我基本原理:

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

 RememberMeAuthenticationFilter在Spring Security中認證過濾器鏈的倒數(shù)第二個過濾器位置,當(dāng)其他認證過濾器都沒法認證成功的時候,就會調(diào)用RememberMeAuthenticationFilter嘗試認證。

實現(xiàn):

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

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

3,在configure里配置

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

//記住我秒數(shù)配置
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;
  //數(shù)據(jù)源
  @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配置,在登錄成功后執(zhí)行
   * 登錄成功后往數(shù)據(jù)庫存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);
    //啟動時自動生成相應(yīng)表,可以在JdbcTokenRepositoryImpl里自己執(zhí)行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();
    //實現(xiàn)需要認證的接口跳轉(zhuǎn)表單登錄,安全=認證+授權(quán)
    //http.httpBasic() //這個就是默認的彈框認證
    //
    http //把驗證碼過濾器加載登錄過濾器前邊
      .addFilterBefore(validateCodeFilter, UsernamePasswordAuthenticationFilter.class)
      //表單認證相關(guān)配置
      .formLogin() 
        .loginPage("/authentication/require") //處理用戶認證BrowserSecurityController
        //登錄過濾器UsernamePasswordAuthenticationFilter默認登錄的url是"/login",在這能改
        .loginProcessingUrl("/authentication/form") 
        .successHandler(imoocAuthenticationSuccessHandler)//自定義的認證后處理器
        .failureHandler(imoocAuthenticationFailureHandler) //登錄失敗后的處理
      .and()
      //記住我相關(guān)配置  
      .rememberMe()
        .tokenRepository(persistentTokenRepository())//TokenRepository,登錄成功后往數(shù)據(jù)庫存token的
        .tokenValiditySeconds(securityProperties.getBrowser().getRememberMeSeconds())//記住我秒數(shù)
        .userDetailsService(userDetailsService) //記住我成功后,調(diào)用userDetailsService查詢用戶信息
      .and()
      //授權(quán)相關(guān)的配置 
      .authorizeRequests() 
        // /authentication/require:處理登錄,securityProperties.getBrowser().getLoginPage():用戶配置的登錄頁
        .antMatchers("/authentication/require",
        securityProperties.getBrowser().getLoginPage(),//放過登錄頁不過濾,否則報錯
        "/verifycode/image").permitAll() //驗證碼
        .anyRequest()    //任何請求
        .authenticated()  //都需要身份認證
      .and()
        .csrf().disable() //關(guān)閉csrf防護
      ;  
  }
}ecurity.browser;

其中由于要和數(shù)據(jù)庫打交道,所以需要注入一個數(shù)據(jù)源: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

啟動應(yīng)用,訪問 localhost:8080/user,需要登錄

登錄成功:

數(shù)據(jù)庫:生成一個persistent_logins表,存進去了一條數(shù)據(jù)

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

請求頭:

至此基本的rememberMe已做好

完整代碼放在了github:https://github.com/lhy1234/spring-security

總結(jié)

以上所述是小編給大家介紹的Spring Security 構(gòu)建rest服務(wù)實現(xiàn)rememberme 記住我功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Mybatis詳細對比一級緩存與二級緩存

    Mybatis詳細對比一級緩存與二級緩存

    MyBatis 包含一個非常強大的查詢緩存特性,它可以非常方便地配置和定制,緩存可以極大的提升查詢效率。MyBatis中默認定義了兩級緩存,分別是一級緩存和二級緩存
    2022-10-10
  • java對接支付寶支付項目的實戰(zhàn)記錄

    java對接支付寶支付項目的實戰(zhàn)記錄

    最近公司有一個需求是接入第三方支付(微信&支付寶),我接到了支付寶支付,所以下面這篇文章主要給大家介紹了關(guān)于java對接支付寶支付項目的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • Java的延遲隊列之DelayQueue解讀

    Java的延遲隊列之DelayQueue解讀

    這篇文章主要介紹了Java的延遲隊列之DelayQueue解讀,DelayQueue的底層存儲是一個PriorityQueue,PriorityQueue是一個可排序的Queue,其中的元素必須實現(xiàn)Comparable接口的compareTo方法,需要的朋友可以參考下
    2023-12-12
  • Java swing 圖像處理多種效果實現(xiàn)教程

    Java swing 圖像處理多種效果實現(xiàn)教程

    這篇文章主要介紹了Java swing 圖像處理多種效果實現(xiàn)教程,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • spring的TransactionSynchronizationAdapter事務(wù)源碼解析

    spring的TransactionSynchronizationAdapter事務(wù)源碼解析

    這篇文章主要介紹了spring的TransactionSynchronizationAdapter事務(wù)源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-09-09
  • SpringBoot+POI實現(xiàn)給word添加水印功能

    SpringBoot+POI實現(xiàn)給word添加水印功能

    這篇文章主要介紹了SpringBoot+POI實現(xiàn)給word添加水印功能,文中通過代碼示例講解的非常詳細,對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-06-06
  • Java8日期類LocalDate、LocalTime和LocalDateTime使用方法詳解

    Java8日期類LocalDate、LocalTime和LocalDateTime使用方法詳解

    這篇文章主要給大家介紹了關(guān)于Java8日期類LocalDate、LocalTime和LocalDateTime使用方法的相關(guān)資料,LocalDateTime是JDK1.8出現(xiàn)的新特性,解決線程不安全的問題,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-11-11
  • Java PriorityQueue優(yōu)點和缺點面試精講

    Java PriorityQueue優(yōu)點和缺點面試精講

    這篇文章主要為大家介紹了Java面試中PriorityQueue的優(yōu)點和缺點及使用注意詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10
  • springboot配置多數(shù)據(jù)源后mybatis攔截器失效的解決

    springboot配置多數(shù)據(jù)源后mybatis攔截器失效的解決

    這篇文章主要介紹了springboot配置多數(shù)據(jù)源后mybatis攔截器失效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • 詳細總結(jié)Java創(chuàng)建文件夾的方法及優(yōu)缺點

    詳細總結(jié)Java創(chuàng)建文件夾的方法及優(yōu)缺點

    很多小伙伴都不知道如何用Java創(chuàng)建文件夾,今天給大家整理了這篇文章,文中有非常詳細的方法介紹及方法的優(yōu)缺點,對正在學(xué)習(xí)java的小伙伴們有很好地幫助,需要的朋友可以參考下
    2021-05-05

最新評論