Spring Session

小编 2026-06-05 阅读:1426 评论:0
开工开工,准备条件:1. 本地Redis,官网:http://redis.io/,windows...

开工开工,

准备条件:

1. 本地Redis,官网:http://redis.io/,windows下

https://github.com/ServiceStack/redis-windows

https://github.com/MSOpenTech/redis/releases msi版本

2. Maven下的项目

 

开始:

1. 依赖配置pom.xml

<dependency> 
<groupId>org.springframework.session</groupId> 
<artifactId>spring-session</artifactId> 
<version>1.0.1.RELEASE</version> 
</dependency> 
<dependency> 
<groupId>com.orange.redis-embedded</groupId> 
<artifactId>embedded-redis</artifactId> 
<version>0.6</version> 
</dependency> 
<dependency> 
<groupId>org.springframework.session</groupId> 
<artifactId>spring-session-data-redis</artifactId> 
<version>1.0.1.RELEASE</version> 
</dependency>

2. web.xml配置

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

3.SpringMVC.xml配置


<!-- spring session redis 配置 -->
<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig"/>

<!--Redis 单机配置 -->
<!-- 
<bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
<property name="hostName" value="127.0.0.1" />
<property name="port" value="6379" /> -->
<!--<property name="password" value="${redis.password}" />-->
<!--<property name="timeout" value="${redis.timeout}" />-->
<!--<property name="poolConfig" ref="jedisPoolConfig" /> -->
<!--<property name="usePool" value="true" /> -->
<!-- </bean> -->

<!-- Redis 集群配置 -->
<!-- 
<bean id="sentinelConfig" class="org.springframework.data.redis.connection.RedisSentinelConfiguration">
<constructor-arg name="master" value="mymaster" />
<constructor-arg name="sentinelHostAndPorts">
<set>
<value>xxx.xx.x.xxx:xxxxx</value>
<value>xxx.xx.x.xxx:xxxxx</value>
<value>xxx.xx.x.xxx:xxxxx</value>
</set>
</constructor-arg>
</bean>
<bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
<constructor-arg ref="sentinelConfig" />
</bean> -->

<!-- 
<bean id="redisTemplate" class="org.springframework.data.redis.core.StringRedisTemplate">
<property name="connectionFactory" ref="jedisConnectionFactory" />
</bean> -->

<!-- 将session放入redis 360分钟-->
<!--
<bean id="redisHttpSessionConfiguration"
class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration"> 
<property name="maxInactiveIntervalInSeconds" value="21600" />
</bean> -->

就着完了,注意看集群配置,因为我是本地没有测试到集群。

这是第一种配置方式,第二种配置,上面的所有配置都不需要,除了pom的依赖文件。

第二种配置,添加两个类文件,什么都不用做了,ok.

@EnableRedisHttpSession 
public class SessionConfig {

@Bean
public JedisConnectionFactory connectionFactory() {
JedisConnectionFactory connection = new JedisConnectionFactory(); 
connection.setPort(6379); 
connection.setHostName("127.0.0.1"); 
return connection; 
}
}

public class SessionInitializer extends AbstractHttpSessionApplicationInitializer 
{
public SessionInitializer() 
{
super(SessionConfig.class);
}
}

 

测试session,你打开你的网站,用浏览器,

打开 redis-cli.exe,执行 keys *,你就可以看到当前所有的keys值,

再打开一个浏览器,再执行 keys *,你会发现多了两个key,一个是记住过期的事件,

你可以打开 浏览器,F12,执行js new Date(value),把你的value贴进去,就知道是什么时候过期了。

 

参考引用:

使用spring-session把http session放到redis里面

Session集群 http://qtdebug.com/spring-security/5.%20Spring-Security-%E9%9B%86%E7%BE%A4.html

Redis配置:http://aiilive.blog.51cto.com/1925756/1627455

 

 

如何在Redis中查看Session数据?


(1)Http Session数据在Redis中是以Hash结构存储的。 
(2)可以看到,还有一个key="spring:session:expirations:1431577740000"的数据,是以Set结构保存的。这个值记录了所有session数据应该被删除的时间(即最新的一个session数据过期的时间)。 

127.0.0.1:6379> keys *1) "spring:session:expirations:1431577740000"2) "spring:session:sessions:e2cef3ae-c8ea-4346-ba6b-9b3b26eee578"127.0.0.1:6379> type spring:session:sessions:e2cef3ae-c8ea-4346-ba6b-9b3b26eee578hash127.0.0.1:6379> type spring:session:expirations:1431577740000set

 

127.0.0.1:6379> keys *1) "spring:session:expirations:1431527520000"2) "spring:session:sessions:59f3987c-d1e4-44b3-a83a-32079942888b"3) "spring:session:sessions:11a69da6-138b-42bc-9916-60ae78aa55aa"4) "spring:session:sessions:0a51e2c2-4a3b-4986-a754-d886d8a5d42d"5) "spring:session:expirations:1431527460000"127.0.0.1:6379> hkeys spring:session:sessions:59f3987c-d1e4-44b3-a83a-32079942888b1) "maxInactiveInterval"2) "creationTime"3) "lastAccessedTime"4) "sessionAttr:attr1"127.0.0.1:6379> hget spring:session:sessions:59f3987c-d1e4-44b3-a83a-32079942888b sessionAttr:attr1"xacxedx00x05srx00x11java.lang.Integerx12xe2xa0xa4xf7x81x878x02x00x01Ix00x05valuexrx00x10java.lang.Numberx86xacx95x1dx0bx94xe0x8bx02x00x00xpx00x00x00x03"127.0.0.1:6379> hget spring:session:sessions:59f3987c-d1e4-44b3-a83a-32079942888b creationTime"xacxedx00x05srx00x0ejava.lang.Long;x8bxe4x90xccx8f#xdfx02x00x01Jx00x05valuexrx00x10java.lang.Numberx86xacx95x1dx0bx94xe0x8bx02x00x00xpx00x00x01MMx94(xec"
版权声明

本文仅代表作者观点,不代表百度立场。
本文系作者授权百度百家发表,未经许可,不得转载。

热门文章
  • 机房智能化温湿度解决方式之POE供电以太网温湿度传感器

    机房智能化温湿度解决方式之POE供电以太网温湿度传感器
    机房智能化温湿度解决方式之POE供电以太网温湿度传感器 北京盈创力和电子科技有限公司 智能型TCP网口温湿度记录仪 北京IP网络温湿度记录仪厂家,北京盈创力和 北京智能型TCP网口温湿度记录仪IP网络温湿度记录仪是一种新型的基于TCP/IP协议双绞线以太网标准温湿度采集模块,利用它可以实现现场温度值、相对湿度值的采集,同时利用其自身的RJ45通信接口可以方便地和机房监控主机或交换机集线器进行联网。 工作于-40℃~85℃工业级带...
  • Sequential Monte Carlo Methods (SMC) 序列蒙特卡洛/粒子滤波/Bootstrap Filtering

    Sequential Monte Carlo Methods (SMC) 序列蒙特卡洛/粒子滤波/Bootstrap Filtering
    Problem Statement 我们考虑一个具有马尔可夫性质、非线性、非高斯的状态空间模型(State Space Model):对于一个时间序列上的观测结果{yt,t∈N}\\{ y_t , t \\in N \\}{yt​,t∈N},我们认为每个观测结果yty_tyt​的生成依赖于一个无法直接观察的隐变量xt∈{xt,t∈N}x_t \\in \\{x_t , t \\in N \\}xt​∈{xt​,t∈N},即:p(...
  • HTTP状态保持的原理

    HTTP状态保持的原理
    a)在用户登录之后,浏览器返回响应的时候会在响应中添加上cookieb)浏览器接收到cookie之后会自动保存c)当用户再次请求同一服务器中的其他网页的时候,浏览器会自动带上之前保存的cookied)服务接收到请求之后可以请 request 对象中取到cookie 判断当前用户是否登录  Http是无状态的,就是连接时数据互通,关闭后...
  • Hive 系统函数及示例

    Hive 系统函数及示例
    查看所有系统函数 show functions; 函数分类 内置函数【系统函数】 数学函数: floor、round、ceil、cos、log2等 字符串函数: length、reverse、trim、lower、get_json_object、repeat等 收集函数: size 转换函数: cast 日期函数: year、month、datediff、date、date_add等 条件函数: coalesce、case…w...
  • CSRF的原理和防范措施

    CSRF的原理和防范措施
    a)攻击原理:i.用户C访问正常网站A时进行登录,浏览器保存A的cookieii.用户C再访问攻击网站B,网站B上有某个隐藏的链接或者图片标签会自动请求网站A的URL地址,例如表单提交,传指定的参数iii.而攻击网站B在访问网站A的时候,浏览器会自动带上网站A的cookieiv.所以网站A在接收到请求之后可判断当前用户是登录状态,所以...
标签列表