session会话过期时间设置

设置Session过期时间
本文介绍了三种设置Session过期时间的方法:通过代码直接设置、在web.xml中进行配置及在应用服务器配置文件中设定。文章详细解释了每种方法的具体操作步骤,并提供了测试代码和注意事项。

具体设置很简单,方法有三种: 
(1)在主页面或者公共页面中加入:session.setMaxInactiveInterval(900); 
参数900单位是秒,即在没有活动15分钟后,session将失效。设置为-1将永不关闭。 
这里要注意这个session设置的时间是根据服务器来计算的,而不是客户端。所以如果是在调试程序,应该是修改服务器端时间来测试,而不是客户端。 
(2)也是比较通用的设置session失效时间的方法,就是在项目的web.xml中设置 
<session-config> 
<session-timeout>15</session-timeout> 
</session-config> 
这里的15也就是15分钟失效. 
(3)直接在应用服务器中设置,如果是tomcat,可以在tomcat目录下conf/web.xml中 
找到<session-config>元素,tomcat默认设置是30分钟,只要修改这个值就可以了,负数或0为不限制session失效时间。 

如图:



需要注意的是如果上述三个地方如果都设置了,有个优先级的问题,从高到低: 
(1)>(2)>(3)

session的过期时间计算是从当前session的最后一次请求开始的。


下面是测试代码:

第一步:配置web.xml(设置失效时间,和监听路径)

1.失效时间单位是分钟,即1分钟后失效

<session-config> 
<session-timeout>1</session-timeout> 
</session-config>

2.设置监听路径 (监听类所在的全路径)

<listener> 
<listener-class> 
com.controller.SessionListener 
</listener-class> 
</listener>

3.新建监听类,代码如下

package com.controller;
import javax.servlet.http.HttpSession;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener;
import org.springframework.stereotype.Controller;
public class SessionListener implements HttpSessionListener{ 
public void sessionCreated(HttpSessionEvent event) { 
HttpSession ses = event.getSession(); 
String id=ses.getId()+ses.getCreationTime(); 
System.out.println("1111111111111"); //创建会话时输出 
} 


public void sessionDestroyed(HttpSessionEvent event) { 
HttpSession ses = event.getSession(); 
String id=ses.getId()+ses.getCreationTime(); 
synchronized (this) { 
System.out.println("2222222222222");//失效时输出
} 
} 
} 

详情链接:http://fengpy2009.iteye.com/blog/834717


### 设置 Session过期时间 在 Web 开发中,Session过期时间是控制用户会话生命周期的重要配置。通过合理设置 Session 的超时时间,可以有效管理服务器资源并提升用户体验。 #### 在 web.xml 中配置 Session 超时时间 可以在 Web 应用的 `web.xml` 文件中配置 Session 的超时时间,单位为分钟。以下是一个配置示例: ```xml <session-config> <session-timeout>30</session-timeout> </session-config> ``` 此配置表示 Session 的默认超时时间为 30 分钟。如果未设置此参数,Tomcat 会使用默认值 30 分钟作为 Session 的超时时间[^2]。此外,也可以在 Tomcat 的全局配置文件 `tomcat/conf/web.xml` 中进行类似设置[^3]。 #### 通过 Java 代码设置 Session 超时时间 除了在配置文件中设置 Session 的超时时间,还可以通过 Java 代码动态设置。调用 `setMaxInactiveInterval()` 方法可以指定 Session 的生命时长(单位为秒)。例如: ```java HttpSession session = request.getSession(); session.setMaxInactiveInterval(60 * 15); // 设置 Session 超时时间为 15 分钟 ``` 如果没有调用此方法,Session 将使用默认的超时时间。 #### 使用 HttpSessionListener 监控 Session 生命周期 为了实现对 Session 生命周期的监控,可以实现 `HttpSessionListener` 接口,并在 `sessionCreated()` 和 `sessionDestroyed()` 方法中添加自定义逻辑。例如: ```java public class OnlineListener implements HttpSessionListener { public void sessionCreated(HttpSessionEvent event) { HttpSession ses = event.getSession(); String id = ses.getId() + ses.getCreationTime(); SummerConstant.UserMap.put(id, Boolean.TRUE); // 添加用户 } public void sessionDestroyed(HttpSessionEvent event) { HttpSession ses = event.getSession(); String id = ses.getId() + ses.getCreationTime(); synchronized (this) { SummerConstant.USERNUM--; // 用户数减一 SummerConstant.UserMap.remove(id); // 从用户组中移除 } } } ``` 通过这种方式,可以在 Session 创建和销毁时执行特定的操作,例如记录用户在线状态或清理资源[^5]。 #### Session 的共享与分布式管理 在分布式环境中,为了实现 Session 的共享,可以通过多种方案进行管理。例如,可以将 Session 数据保存到统一的存储系统中,如 Memcached 或 Redis。此外,还可以通过配置负载均衡器(如 Nginx)使用 `ip_hash` 算法,确保来自同一 IP 的请求固定分配到某个后端服务器,从而解决 Session 共享问题[^4]。 另外,利用开源项目如 `memcached-session-manager` 或 `tomcat-redis-session-manager` 可以实现对 Tomcat 的 Session 管理扩展。这些工具允许将 Session 数据存储到外部缓存中,从而实现跨服务器的 Session 共享[^4]。 #### 使用 Spring-Session 实现自定义 Session 管理 Spring-Session 提供了一种灵活的方式来管理 Session 数据。通过实现 `HttpSessionStrategy` 接口,可以自定义 Session 的创建和管理逻辑。例如,可以通过配置 Redis 来实现 Session 的持久化存储: ```java @EnableRedisHttpSession public class SessionConfig { // 配置 Redis 连接信息 } ``` 此方法通过拦截 `HttpServletRequest` 并重写 `getSession()` 方法,实现了对 Session 的接管控制[^4]。 --- ###
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值