关于java web 开发中session过期的理解

最近做一个项目要求实现一个功能。

就是如果用户A已经登录到系统中。如果其他人再使用用户A的帐号在其他机器或者浏览器上登录,都会登录失败。只能等待用户A在系统中注销或者Session超时才可以登录。

 

这个项目是用java web相关技术实现的。 其实实现的原理比较简单就是将用户登录后将session保存到一段共享的内存中(程序中是用静态的HashTable保存所有的Session)。

 

其中当用户的session过期失效后。我发现map中的session对象依然存在。不过从HashTable得到这个过期后的session对象调用getAttribute()方法时。会抛出一个session已经失效的异常。而在session失效后用request.getSession()取得的Session对象并不是保存在HashTable中的session对象。两者有着不同的sessionID  和 session对象地址。 前者可以使用getAttribute()这样的方法,不过由于是新的对象所以没有属性值。

 

 

这样的结果可以推出服务器对session过期管理的结论: session的过期失效,实际上服务器会重新创建一个session对象将对原来session对象的引用指向新的session并将sessionID发送给客户端保存以替换原来的sessionID。 而旧的session对象由于客户端的sessionID已经修改将不会被获得。旧的session对象等待jvm垃圾回收进程进行垃圾回收。

 

* 注: 不过这个项目中由于session过期后session的引用保存在静态的HashTable中使得就得session对象不会被垃圾回收器回收。 HashTable会随着系统的运行变得越来越大。注意到这个问题后。使用了session监听器当session失效后捕获其session对象并从HashTable中移出。从而达到理想的效果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Java,可以通过实现`HttpSessionListener`接口来监听session的创建和销毁事件。具体步骤如下: 1. 创建一个类并实现`HttpSessionListener`接口。 ```java public class MySessionListener implements HttpSessionListener { @Override public void sessionCreated(HttpSessionEvent se) { // session创建时执行的操作 } @Override public void sessionDestroyed(HttpSessionEvent se) { // session销毁时执行的操作 } } ``` 2. 在`web.xml`文件配置listener。 ```xml <listener> <listener-class>com.example.MySessionListener</listener-class> </listener> ``` 3. 在`sessionCreated`和`sessionDestroyed`方法编写相应的操作逻辑。 例如,可以在`sessionCreated`方法记录session的创建时间,而在`sessionDestroyed`方法记录session的销毁时间,并计算出session的生命周期。如果session的生命周期超过一定时间,则可以认为该session过期。 ```java @Override public void sessionCreated(HttpSessionEvent se) { HttpSession session = se.getSession(); session.setAttribute("createTime", System.currentTimeMillis()); } @Override public void sessionDestroyed(HttpSessionEvent se) { HttpSession session = se.getSession(); long createTime = (long) session.getAttribute("createTime"); long destroyTime = System.currentTimeMillis(); long sessionTime = destroyTime - createTime; if (sessionTime > 30 * 60 * 1000) { // session过期,执行相应的操作 } } ``` 在上述例子,30 * 60 * 1000表示session的最大生命周期为30分钟。如果session的生命周期超过了30分钟,则可以认为该session过期

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wp500

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值