使用springSession完成分布式session
分布式session可以使用spring session来进行实现,由于HttpRequest的Wrapper功能,许多HttpRequest中的方法都可以进行替换来进行自定义的重写,可以在Wrapper中将getSession方法重写掉,然后进行自定义的session存储和处理,当然了,你能想到的,一般都是早就有人已经实现了,就不重复造轮子了
spring session已经实现出了上述功能,只需要进行配置就可以实现啦
这里演示的是将session存储在redis中,所需要的依赖
1 2 3 4 5 6 7 8 9 10 11
| <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的配置文件中配置
1 2 3 4 5 6 7 8 9
|
<bean class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration"/>
<bean class="org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory"> <constructor-arg name="host" value="localhost"/> <constructor-arg name="port" value="6379"/> </bean>
|
只是配置这个是不够的,RedisHttpSessionConfiguration中根本就没有提到HttpServletRequestWrapper呀,所以还要配置一个过滤器
1 2 3 4 5 6 7 8 9 10 11
| <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了
1 2 3 4
| 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"
|