SpringMVC使用oracle配置session共享

本文介绍了在SpringMVC项目集群部署时遇到的Session丢失问题,通过使用Spring Session JDBC解决方案,详细讲解了如何配置数据库表、添加Maven依赖、修改`application.xml`和`web.xml`,并添加过滤器实现Session共享,确保用户登录状态在集群中的持久化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简述

由于开发是单机项目,但是到了配置负载均衡的集群中就发生了问题,使用账号登录后又跳回主页面。

我分析了原因是负载均衡配置的跳转是每次访问都会切换服务,所以在A机器登录后,再次访问B机器找不到有登录状态的session,而我的过滤器里面配置了不登录就会跳到首页,所以在B机器上给跳回了首页,这样就会一直登陆失败。
解决办法就是配置session共享,看了大多数的session共享都是用的Redis做的,但是本着不增加项目架构复杂度的想法,便使用了本身的项目数据库–oracle

使用了spring提供的session共享方案,spring-session

spring-session的Github地址:https://github.com/spring-projects/spring-session

数据库表

使用JDBC做session共享需要在对应库中增加表,里面包含了各种库的对应的表信息,可参考: https://github.com/spring-projects/spring-session/tree/master/spring-session-jdbc/src/main/resources/org/springframework/session/jdbc

这里是2.x版本的sql,如果是1.x版本是没有PRIMARY_ID字段的,要在下面maven依赖中选择对应的版本,不然运行报错。

CREATE TABLE SPRING_SESSION (
   PRIMARY_ID CHAR(36) NOT NULL,
   SESSION_ID CHAR(36) NOT NULL,
   CREATION_TIME NUMBER(19,0) NOT NULL,
   LAST_ACCESS_TIME NUMBER(19,0) NOT NULL,
   MAX_INACTIVE_INTERVAL NUMBER(10,0) NOT NULL,
   EXPIRY_TIME NUMBER(19,0) NOT NULL,
   PRINCIPAL_NAME VARCHAR2(100 CHAR),
   CONSTRAINT SPRING_SESSION_PK PRIMARY KEY (PRIMARY_ID)
   );

   CREATE UNIQUE INDEX SPRING_SESSION_IX1 ON SPRING_SESSION (SESSION_ID);
   CREATE INDEX SPRING_SESSION_IX2 ON SPRING_SESSION (EXPIRY_TIME);
   CREATE INDEX SPRING_SESSION_IX3 ON SPRING_SESSION (PRINCIPAL_NAME);

   CREATE TABLE SPRING_SESSION_ATTRIBUTES (
   	SESSION_PRIMARY_ID CHAR(36) NOT NULL,
   	ATTRIBUTE_NAME VARCHAR2(200 CHAR) NOT NULL,
   	ATTRIBUTE_BYTES BLOB NOT NULL,
   	CONSTRAINT SPRING_SESSION_ATTRIBUTES_PK PRIMARY KEY (SESSION_PRIMARY_ID, ATTRIBUTE_NAME),
   	CONSTRAINT SPRING_SESSION_ATTRIBUTES_FK FOREIGN KEY (SESSION_PRIMARY_ID) REFERENCES SPRING_SESSION(PRIMARY_ID) ON DELETE CASCADE
   );

Maven依赖

这里对应的找到2.x版本的依赖,如果没有maven,要引入如下jar:spring-jdbc、spring-session-core、spring-context

 <dependency>
    <groupId>org.springframework.session</groupId>
    <artifactId>spring-session-jdbc</artifactId>
    <version>2.0.2.RELEASE</version>
 </dependency>

application.xml配置

<context:annotation-config/>
<bean class="org.springframework.session.jdbc.config.annotation.web.http.JdbcHttpSessionConfiguration">
       <property name="tableName" value="spring_session"/>
       <property name="maxInactiveIntervalInSeconds" value="1800"/>
 </bean>
<!-- 配置事务管理器 -->
<bean id="transactionManager"
    class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
       <!-- 注入数据库连接池 -->
       <property name="dataSource" ref="dataSource" />
 </bean>

web.xml

spring session通过自定义一个filter,通过filter职责链将用自己定义的request替换httpservletrequest,从而使用自己httpsession。配置一下Filter,把他放在最前面,使其优先执行

   <filter>
       <filter-name>springSessionRepositoryFilter</filter-name>
       <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
   </filter>
   <filter-mapping>
       <filter-name>springSessionRepositoryFilter</filter-name>
       <url-pattern>/*</url-pattern>
   </filter-mapping>

总结

整和共享session步骤:增加数据库表,添加依赖,配置spring的xml,增加过滤器让request获取spring-session-jdbc中的session

整合之后,可以登录到项目中,并在数据库的SPRING_SESSIONSPRING_SESSION_ATTRIBUTES表中看到相应的信息,而session存活时间也与原来相同,不影响其他逻辑。

参考

官方文档
XML配置spring session jdbc实现session共享

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值