加入收藏 | 设为首页 | 会员中心 | 我要投稿 西安站长网 (https://www.029zz.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 业界 > 正文

Tomcat 中的 Session 和 Cookie的爱恨情仇

发布时间:2019-05-16 10:34:11 所属栏目:业界 来源:顿悟源码
导读:副标题#e# HTTP 是一种无状态通信协议,每个请求之间相互独立,服务器不能识别曾经来过的请求。而对于 Web 应用,它的活动都是依赖某个状态的,比如用户登录,此时使用 HTTP 就需要它在一次登录请求后,有为后续请求提供已登录信息的能力。 解决办法就是使

一个 Web 应用对应一个会话管理器,也就是说 StandardContext 内部有一个 Manager 实例。每个容器组件都会启动一个后台线程,周期的调用自身以及内部组件的 backgroundProcess() 方法,Manager 后台处理就是检查 Session 是否过期。

检查的逻辑是,获取所有 session 使用它的 isValid 判断是否过期,代码如下:

  1. public boolean isValid() { 
  2.   ... 
  3.   // 是否检查是否活动,默认 false 
  4.   if (ACTIVITY_CHECK && accessCount.get() > 0) { 
  5.     return true; 
  6.   } 
  7.   // 检查时间是否过期 
  8.   if (maxInactiveInterval >= 0) {  
  9.     long timeNow = System.currentTimeMillis(); 
  10.     int timeIdle = (int) ((timeNow - thisAccessedTime) / 1000L); 
  11.     if (timeIdle >= maxInactiveInterval) { 
  12.       // 如果过期,执行一些内部处理 
  13.       // 主要是通知对过期事件感兴趣的 listeners 
  14.       expire(true); 
  15.     } 
  16.   } // 复数永不过期 
  17.   return (this.isValid); 

3.3 Session 持久化

(编辑:西安站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读