使用springSession完成分布式session

简介: 本文介绍了如何使用 `spring-session` 实现分布式 Session 管理,并提供了将 Session 存储在 Redis 中的具体配置示例。通过配置相关依赖及 Spring 的配置文件,可以轻松实现 Session 的分布式存储。示例中详细展示了所需的 Maven 依赖、Spring 配置及过滤器配置,并给出了启动项目后在 Redis 中查看 Session 数据的方法。

使用springSession完成分布式session

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

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

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

xml

代码解读

复制代码

        <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的配置文件中配置

xml

代码解读

复制代码

<!-- 测试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呀,所以还要配置一个过滤器

xml

代码解读

复制代码

<!-- 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了

shell

代码解读

复制代码

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://juejin.cn/post/7371641968601235508

相关文章
|
存储 API
一种新的方法来存储用户信息——ThreadLocal
一种新的方法来存储用户信息——ThreadLocal
1472 0
|
NoSQL Java 应用服务中间件
大厂面试必备:如何轻松实现分布式Session管理?
这篇文章介绍三种分布式Session的实现方案:基于JWT的Token、基于Tomcat的Redis和基于Spring的Redis。JWT方案通过生成Token存储用户信息,实现无状态、可扩展的会话管理,但可能增加请求负载且数据安全性较低。Tomcat与Redis结合,通过配置Tomcat和Redis,实现Session集中管理和高性能存储,但配置相对复杂。Spring整合Redis适用于SpringBoot和SpringCloud项目,集成方便,扩展性强,但同样依赖外部Redis服务。每种方法有其优缺点,适用场景不同。作者小米是一个技术爱好者,欢迎关注其微信公众号“软件求生”获取更多技术内容
621 4
|
网络协议 NoSQL Linux
阿里云 Linux 内核优化实战(sysctl.conf 和 ulimits )
一、sysctl.conf优化Linux系统内核参数的配置文件为 /etc/sysctl.conf 和 /etc/sysctl.d/ 目录。其读取顺序为: /etc/sysctl.d/ 下面的文件按照字母排序;然后读取 /etc/sysctl.conf 。
9175 1
|
XML Java 数据库
探索 Spring Boot 中的 @Configuration 注解:核心概念与应用
【4月更文挑战第20天】在 Spring Boot 项目中,@Configuration 注解扮演了一个关键角色,它标识一个类作为配置源,这些配置用于定义和管理 Spring 应用程序中的 Bean
2291 7
|
10月前
|
Linux
如何在 Linux 系统中查看进程占用的内存?
如何在 Linux 系统中查看进程占用的内存?
1281 58
|
10月前
|
安全 Java 测试技术
如何在 Spring Boot 中禁用 Actuator 端点安全?
如何在 Spring Boot 中禁用 Actuator 端点安全?
1846 1
|
12月前
|
小程序 JavaScript 前端开发
微信小程序安装和使用 Vant Weapp 组件库
本文介绍了如何在微信小程序中安装和使用Vant Weapp组件库,包括通过npm安装、构建npm、修改配置文件以及在小程序中使用Vant Weapp提供的组件。
微信小程序安装和使用 Vant Weapp 组件库
|
NoSQL Java 数据库连接
springboot整合Redis中连接池jedis与lettuce的对比和实现
springboot整合Redis中连接池jedis与lettuce的对比和实现
2018 0
|
存储 安全 Java
“Spring Security 中的 Principal 是什么?
【8月更文挑战第21天】
979 0
|
Java 数据库 索引
【Java】已解决Spring框架中的org.springframework.dao.DuplicateKeyException异常
【Java】已解决Spring框架中的org.springframework.dao.DuplicateKeyException异常
479 0