使用springSession完成分布式session

使用springSession完成分布式session

分布式session可以使用spring session来进行实现,由于HttpRequest的Wrapper功能,许多HttpRequest中的方法都可以进行替换来进行自定义的重写,可以在Wrapper中将getSession方法重写掉,然后进行自定义的session存储和处理,当然了,你能想到的,一般都是早就有人已经实现了,就不重复造轮子了

spring session已经实现出了上述功能,只需要进行配置就可以实现啦

这里演示的是将session存储在redis中,所需要的依赖

复制代码
        <dependency>
            <groupId>org.springframework.session</groupId>
            <artifactId>spring-session-data-redis</artifactId>
            <version>1.3.5.RELEASE</version>
        </dependency>

        <dependency>
            <groupId>biz.paluch.redis</groupId>
            <artifactId>lettuce</artifactId>
            <version>3.4.2.Final</version>
        </dependency>

在spring的配置文件中配置

复制代码
<!-- 测试spring-session
     httpSession存储在redis
     -->
<bean class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration"/>
<!-- redis的连接工厂 -->
<bean class="org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory">
  <constructor-arg name="host" value="localhost"/>
  <constructor-arg name="port" value="6379"/>
</bean>

只是配置这个是不够的,RedisHttpSessionConfiguration中根本就没有提到HttpServletRequestWrapper呀,所以还要配置一个过滤器

复制代码
<!-- filter的名字不要改变,这个DelegatingFilterProxy类是根据名字去加载bean的 -->
<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>
    <dispatcher>REQUEST</dispatcher>
    <dispatcher>ERROR</dispatcher>
</filter-mapping>

为什么要使用DelegatingFilterProxy,而不直接去使用springSessionRepositoryFilter呢?因为springSessionRepositoryFilter没有默认构造器,需要传入参数sessionRepository,而这个sessionRepository是spring管理的一个bean,那就只好也将springSessionRepositoryFilter作为一个bean去处理,所以就使用DelegatingFilterProxy,它的功能就是会从spring上下文中去查找

启动项目之后正常的向往常一样的操作session,就可以看到redis中存有session了

复制代码
127.0.0.1:6379> keys *
1) "spring:session:expirations:1623743940000"
2) "spring:session:sessions:3fbe4ab6-b9ff-4065-8c07-b0ed7f02a4db"
3) "spring:session:sessions:expires:3fbe4ab6-b9ff-4065-8c07-b0ed7f02a4db"

https://zhhll.icu/2021/框架/springmvc/分布式session/使用springSession完成分布式session/

本文由mdnice多平台发布

相关推荐
C++chaofan3 分钟前
JUC 并发编程从入门到精通(超详细笔记 + 实战案例)
java·jvm·spring boot·redis·后端·并发·juc
zhaokuner9 分钟前
02-通用语言与协作-DDD领域驱动设计
java·开发语言·设计模式·架构
小毅&Nora14 分钟前
【后端】【JAVA】JDK 21与JDK 7 JVM结构及GC算法深度解析:从永久代到元空间,从CMS到ZGC的演进
java·jvm·gc
寻星探路16 分钟前
网络原理全景图:从通信起源到 TCP/IP 体系架构深度拆解
java·网络·c++·python·tcp/ip·http·架构
未来之窗软件服务22 分钟前
幽冥大陆(八十八 ) 操作系统应用封装技术C#自解压 —东方仙盟练气期
java·前端·c#·软件打包·仙盟创梦ide·东方仙盟·阿雪技术观
技术小泽23 分钟前
java转go速成入门笔记篇(一)
java·笔记·golang
你不是我我23 分钟前
【Java 开发日记】我们来说一下 MySQL 的慢查询日志
android·java·mysql
C雨后彩虹24 分钟前
ReentrantLock入门:核心特性与基本使用
java·数据结构·reentrantlock·lock
资生算法程序员_畅想家_剑魔24 分钟前
Java常见技术分享-27-事务安全-事务日志-事务日志框架
java·开发语言
古城小栈28 分钟前
内存对决:rust、go、java、python、nodejs
java·golang·rust