`
m635674608
  • 浏览: 5031563 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

spring session无法实现共享(多web应用)

 
阅读更多

问题背景

  • 最近在做一个session共享的业务,接手的项目中是通过tomcat-redis-session-manager-master这个jar包实现的session共享,该jar包依赖于tomcat容器。而现在的项目需求是不依赖于特定容器,对该项目的session共享进行相关修改。通过查找相关资料,发现spring session符合要求。对于spring session的相关介绍,这里就不做阐述了,看官可自行查找。

问题描述

  • 接手的项目中通过多个web应用的war包进行项目协作,然而在使用spring session进行session共享的时候,发现各web都是单独的sessionId,并且存储在Redis中。也就是说,各web应用之间并没有实现session共享,从而也就无法实现单点登录功能。

问题解决

  • 通过查看spring session相关源码发现,在包路径 org.springframework.session.web.http下有一个DefaultCookieSerializer类,该类有一个方法getCookiePath(HttpServletRequest request),下面为源码相关内容,其中的syso为我调试的时候自己打印的log。
private String getCookiePath(HttpServletRequest request) {
        if (this.cookiePath == null) {
            System.out.println("cookiePath-->" + request.getContextPath());
            return request.getContextPath() + "/";
        }
        return this.cookiePath;
    }
  • 通过上面的打印log,我发现该方法返回的cookiePath是web项目的子域路径,也就是说,如果一个项目为localhost:8080/abc,另一个项目为localhost:8080/def(该端口也可以不为8080),那么spring session就会认为两个项目的cookiePath分别为/abc和/def,从而也就认定这两个项目不为同一个cookiePath,最终也就导致问题的出现,无法实现session共享。
  • 解决该问题,我们可以通过修改源码返回的cookiePath,使得其认为的cookiePath路径一致,修改后的源码为:
private String getCookiePath(HttpServletRequest request) {
//      if (this.cookiePath == null) {
//          System.out.println("cookiePath-->" + request.getContextPath());
//          return request.getContextPath() + "/";
//      }
//      return this.cookiePath;
        return "/";
    }

此方式为所有返回的cookiePath都为“/”,也就使得各web应用的cookiePath一致了。当然,具体的修改还要根据实际项目进行,但是最终解决的思路是一样的,各web应用返回的cookiePath一致

  • 对于如何修改源码
    1.第一种比较直接暴力的就是修改spring seesion源码,并重新打成jar包
    2.第二种就是让程序复用DefaultCookieSerializer类,在每个web项目中分别新建一个类DefaultCookieSerializer类,先假如该类所在的包为com.test,复制源码中DefaultCookieSerializer类的内容放入你自己新建的DefaultCookieSerializer类中,由于篇幅问题,我就不把DefaultCookieSerializer类的内容放出来了,只要按上面所说的将getCookiePath(HttpServletRequest request)返回值修改就可以了。新建类中在这个地方会出现报错:
    private boolean isServlet3()
    {
//        ServletRequest.getMethod("startAsync", new Class[0]);
        return true;
//        NoSuchMethodException nosuchmethodexception;
//        nosuchmethodexception;
//        return false;
    }

为了方便演示,我就直接将相关报错注释掉了,看官可自行斟酌。
3.第三种就是修改各个web应用的域名,还是那句话,最终解决的思路是一样的,让spring session对各web应用返回的cookiePath一致
4.新建好DefaultCookieSerializer类之后,需要修改applicationContext.xml(我的项目是直接在该xml中进行spring session相关配置,看官可根据自己项目在相应的xml中对spring session进行配置),在xml中添加以下内容:

<bean id="defaultCookieSerializer" class="com.test.DefaultCookieSerializer" />
    <bean class="org.springframework.session.web.http.CookieHttpSessionStrategy">
        <property name="cookieSerializer" ref="defaultCookieSerializer" />
    </bean>
    <bean class="org.springframework.session.config.annotation.web.http.SpringHttpSessionConfiguration">
        <property name="cookieSerializer" ref="defaultCookieSerializer" />
    </bean>

5.至此,对于spring session多web应用无法实现session共享的问题解决了。

总结

  • 看官如果遇到这种问题,可以尝试使用本文所阐述的方法进行相关配置。如果不行的话,请继续填坑,加油!
  • 本文使用的spring session包版本为spring-session-1.2.1-RELEASE.jar,可能不同的版本包内容上会有些不同,还是那句话,最终解决的思路是一样的,让spring session对各web应用返回的cookiePath一致,重要的事终于说了3遍了

http://www.jianshu.com/p/a4f49e73bce6
分享到:
评论

相关推荐

    spring session实现session共享

    Spring Session 是一个开源项目,由 Pivotal Software 开发,旨在提供一种在分布式环境中实现Session共享的解决方案。在传统的Web应用中,Session信息通常存储在单个服务器的内存中,当应用部署在集群或者分布式环境...

    Spring Session + redis实现session共享

    在现代Web应用开发中,session共享是一个至关重要的需求,特别是在分布式系统中,多个服务器节点需要共享用户的状态信息。Spring Session + Redis的结合提供了一个高效且可靠的解决方案,它允许跨服务器节点透明地...

    学习Spring-Session+Redis实现session共享

    本节将详细介绍如何使用Spring-Session结合Redis来实现Session共享,包括必要的依赖项添加、配置以及具体的应用示例。 ##### 1. 添加依赖 为了使用Spring-Session,首先需要在项目中添加相应的Maven依赖。下面展示...

    spring redis session共享实现步骤

    在现代Web应用开发中,Session共享是一个常见的需求,特别是在分布式系统中。Spring框架结合Redis作为Session存储机制,能够有效地解决这个问题。以下将详细介绍如何通过Spring和Redis实现Session共享的步骤。 1. *...

    SpringSession+Redis实现Session共享案例

    SpringSession结合Redis实现Session共享是Web开发中一种常见的解决方案,特别是在分布式系统中,为了保持用户在不同服务器之间访问时的会话一致性。本案例旨在教你如何配置和使用SpringSession与Redis来达到这一目的...

    springboot +shiro+redis实现session共享(方案二)1

    本文档旨在介绍如何使用 Spring Boot、Shiro 和 Redis 实现分布式 session 共享,以解决 Web 应用程序的登录 session 统一问题。 2. 相关依赖 在实现 session 共享之前,需要在项目中引入相关依赖项,包括: * ...

    springsession管理多台tomcatsession

    尤其在处理多台 Tomcat 服务器时,SpringSession 提供了一种优雅的方式来实现 session 共享,避免了传统的 sticky sessions 或者基于 cookie 的解决方案的局限性。在本场景中,我们将讨论如何利用 SpringSession 将 ...

    spring session redis分布式session

    它的核心功能是在多个应用服务器之间共享Session,从而打破了传统Session的单服务器局限性。Spring Session支持多种存储机制,包括内存、数据库、Redis等,这里我们重点讨论Redis方案。 **2. Redis作为Session存储*...

    SpringSession同时支持Cookie和header策略

    SpringSession的实现允许自定义Cookie的名称、过期时间以及安全性设置,以适应不同的应用场景。 而header策略则是将session ID放入HTTP请求的头部,比如X-Auth-Token或类似的自定义头部。这种方法可以避免Cookie的...

    Springboot+SpringSecurity+SpringSession+Redis+Mybatis-Plus+Swwager.zip

    本项目“Springboot+SpringSecurity+SpringSession+Redis+Mybatis-Plus+Swwager”整合了Spring Boot、Spring Security、Spring Session、Redis、Mybatis-Plus以及Swagger等技术,旨在构建一个强大的、安全的、具有...

    ssm+redis 实现session共享

    SSM+Redis 实现Session共享是现代Web应用中常见的技术组合,主要目的是在分布式系统中保持用户Session的一致性。SSM是指Spring、Spring MVC和MyBatis这三大Java Web开发框架的组合,而Redis则是一种高性能的键值存储...

    springboot 项目,基于springsession整合redis实现登录拦截功能

    在这样的系统中,用户会话(Session)管理成为一个挑战,因为传统的基于HTTP Session的方法无法在多个服务之间共享数据。Spring Session应运而生,它提供了一种在分布式环境中管理Session的解决方案。本项目是基于...

    SpringBoot集成Spring Security登录管理 添加 session 共享【完整源码+数据库】

    在本文中,我们将深入探讨如何在SpringBoot应用中集成Spring Security进行登录管理,并实现session共享。这是一项关键的安全措施,可以确保用户会话在多个微服务之间的一致性。我们将基于给定的标签——SpringBoot、...

    解决springboot实现跨域session共享问题

    本文将详细讲解如何在Spring Boot应用中解决跨域session共享的问题,并探讨防止SQL注入的相关策略。 首先,让我们理解什么是跨域。跨域是指由于浏览器的同源策略限制,不同域名、协议或端口之间的页面无法直接通信...

    spring session实现分布式会话管理

    在传统的 Web 应用中,Session 是在单个服务器上创建和管理的,当应用部署在多台服务器上时,会话信息无法跨服务器共享,导致用户在切换服务器时丢失会话状态。分布式会话管理就是为了解决这个问题,使得用户的会话...

    spring-session例子工程

    在传统的 Web 应用中,Session 数据通常存储在单个服务器的内存中,当应用部署在多台服务器上时,每台服务器都独立维护自己的 Session,导致用户在切换服务器时会话无法共享,从而影响用户体验。Spring Session 提供...

    spring session入门

    传统的HttpSession在单服务器环境下工作良好,但随着微服务和分布式系统的普及,session共享成为挑战。Spring Session通过将session数据存储在集中式存储(如Redis)中,解决了这个问题。这样,即使用户请求分发到...

    Spring-session2整合spring5+redis

    标题中的“Spring-session2整合spring5+redis”指的是在Spring框架的第五个主要版本(Spring 5)中,集成Spring Session 2与Redis数据库来管理Web应用的会话(Session)。Spring Session是一个开源项目,旨在提供一...

    spring4+redis3+nginx1实现tomcat集群session共享源码

    本文将详细介绍如何使用Spring、Redis和Nginx来实现Tomcat集群中的Session共享,以及提供相关的源码下载。 首先,我们来看Spring框架。Spring是Java开发中最流行的开源框架之一,它提供了丰富的功能和模块,包括...

Global site tag (gtag.js) - Google Analytics