中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

SpringBoot2.x版本中,使用SpringSession常見問題及解決方法

發布時間:2021-07-02 15:43:39 來源:億速云 閱讀:271 作者:chen 欄目:開發技術

本篇內容主要講解“SpringBoot2.x版本中,使用SpringSession常見問題及解決方法”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“SpringBoot2.x版本中,使用SpringSession常見問題及解決方法”吧!

SpringBoot2.x SpringSession踩坑

Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.BeanCreationException: Error creating bean with name ‘org.springframework.boot.autoconfigure.session.SessionAutoConfiguration$ServletSessionRepositoryValidator': Invocation of init method failed; nested exception is org.springframework.boot.autoconfigure.session.SessionRepositoryUnavailableException: No session repository could be auto-configured, check your configuration (session store type is ‘redis')

這是因為缺少了spring-session-data-redis依賴。

關于SpringBoot2.X中,引用SpringSession,同時使用Redis存儲緩存數據需要進行如下配置:

 <!--SpringSession依賴-->
 <dependency>
  <groupId>org.springframework.session</groupId>
  <artifactId>spring-session-core</artifactId>
 </dependency>
 <!--SpringSessionRedis依賴-->
 <dependency>
  <groupId>org.springframework.session</groupId>
  <artifactId>spring-session-data-redis</artifactId>
 </dependency>
#使用使用Redis緩存session數據
spring.session.store-type=REDIS
#Redis服務器地址
spring.redis.host=127.0.0.1
#Redis服務器端口號
spring.redis.port=6379

總結:

在SpringBoot2.x的版本中,引用spring-session-core時,不是對spring-session-data-redis進行加載,需要用戶自己添加關于spring-session與redis的關聯依賴。

springboot 2.x 踩坑——跨域導致session問題

目前IT界主流前后端分離,但是在分離過程中一定會存在跨域的問題。

什么是跨域?

是指瀏覽器從一個域名的網頁去請求另一個域名的資源時,域名、端口、協議任一不同,都是跨域。

遇到的場景

當我們用springboot + shrio +vue 來做后臺管理的項目時,無法獲取shiroSession當前登錄的用戶,

于是我們就排查,網上說在跨域時讓session通過就可以了

后端

@Configuration
public class CorsConfig {
    private CorsConfiguration buildConfig() {
        CorsConfiguration corsConfiguration = new CorsConfiguration();
        corsConfiguration.setAllowCredentials(true);
        // 允許任何域名使用
        corsConfiguration.addAllowedOrigin("*");
        // 允許任何頭
        corsConfiguration.addAllowedHeader("*");
        // 允許任何方法(post、get等)
        corsConfiguration.addAllowedMethod("*");
        corsConfiguration.setMaxAge(3600L);
        return corsConfiguration;
    }
    @Bean
    public CorsFilter corsFilter() {
        UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
        // 對接口配置跨域設置
        source.registerCorsConfiguration("/**", buildConfig());
        return new CorsFilter(source);
    }
}

前端

axios.defaults.withCredentials=true;

但是設置后依舊不行

經過一天的百度與排查,我回滾到springboot 1.x 居然沒有這個問題,才定位到是升級到springboot 2.x導致的原因,好了,已經抓住兇手了,這下子好對癥下藥了,去網上看了 springboot升級到2.x spring session 相關的問題。

終于發現了新大陸,spring-session 2.x 中 Cookie里面居然引入了SameSite 這個叼毛,他默認值是 Lax,好了咱們來看看這個是什么東西?

SameSite Cookie 是用來防止CSRF攻擊,它有兩個值:Strict、Lax

SameSite = Strict:

意為嚴格模式,表明這個cookie在任何情況下都不可能作為第三方cookie;

SameSite = Lax:

意為寬松模式,在GET請求是可以作為第三方cookie,但是不能攜帶cookie進行跨域post訪問(這就很蛋疼了,我們那個校驗接口就是POST請求)

總結:前端請求到后臺,每次session都不一樣,每次都是新的會話,導致獲取不到用戶信息

解決方案:

將SameSite設置為空

@Configuration
public class SpringSessionConfig { 
    @Bean
    public CookieSerializer httpSessionIdResolver() {
        DefaultCookieSerializer cookieSerializer = new DefaultCookieSerializer();
        // 取消僅限同一站點設置
        cookieSerializer.setSameSite(null);
        return cookieSerializer;
    }
}

問題解決!!

到此,相信大家對“SpringBoot2.x版本中,使用SpringSession常見問題及解決方法”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

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

AI

凤翔县| 卢龙县| 河曲县| 文化| 秦安县| 崇明县| 红原县| 卫辉市| 丹东市| 张掖市| 高淳县| 叙永县| 宿迁市| 德格县| 交口县| 沂水县| 丽江市| 读书| 赤城县| 崇义县| 丰顺县| 大同市| 铁岭县| 东至县| 日照市| 老河口市| 邻水| 西峡县| 县级市| 台江县| 卓尼县| 喀什市| 册亨县| 浠水县| 涞源县| 平遥县| 石阡县| 遂平县| 汽车| 鄱阳县| 宕昌县|