前言
前面我们将 Redis 集成到工程中来了,现在需要用它来做点实事了。这次为了解决分布式系统中的 session 共享的问题,将 session 托管到 Redis。
正文
引入依赖
除了上篇文章中引入 spring-boot-starter-data-redis
,还需要 spring-session
依赖:
<dependency>
<groupId>org.springframework.session</groupId>
<artifactId>spring-session</artifactId>
</dependency>
配置
在系统的配置文件中加入:
spring:
session:
store-type: redis
并且可以发现 store-type
有几种值可以设置,都是可以作为 session 共享的媒介。
可以看到,Spring Session 支持使用Redis、Mongo、JDBC、Hazelcast来存储Session,
这样就完成了。
测试
可以看出,session 已经被 shiro 接管了。
spring-session 实现的思路是:设计一个Filter,利用 HttpServletRequestWrapper
,实现自己的 getSession()方法
,接管创建和管理Session数据的工作。