2019-06-10

Session

HttpSession 对象是 javax.servlet.http.HttpSession 的实例,该接口并不像

HttpServletRequest 或 HttpServletResponse 还存在一个父接口,该接口只是一个

纯粹的接口。这因为 session 本身就属于 HTTP 协议的范畴。

对于服务器而言,每一个连接到它的客户端都是一个 session,servlet 容器

使用此接口创建 HTTP 客户端和 HTTP 服务器之间的会话。会话将保留指定的时间段,跨多个连接或来自用户的页面请求。

session 无论客户端还是服务器端都可以感知到,若重新打开一个新的浏览器,则无法取得之前设置的 session,因为每一个 session 只保存在当前的浏览器当中,并在相关的页面取得。

Session的作用

Session 的作用就是为了标识一次会话,或者说确认一个用户;并且在一次

会话(一个用户的多次请求)期间共享数据。我们可以通过 req.getSession()方

法,来获取当前会话的 session 对象。

HttpSession  session= req.getSession();

标识会话JSESSIONID

Session 既然是为了标识一次会话,那么此次会话就应该有一个唯一的标志,

这个标志就是 sessionId。

每当一次请求到达服务器,如果开启了会话(访问了 session),服务器第一

步会查看是否从客户端回传一个名为 JSESSION 的 cookie,如果没有则认为这是

一次新的会话,会创建 一个新的 session 对象,并用唯一的 sessionId 为此次

会话做一个标志。

这里提到一个叫做 JSESSION 的 cookie,这是一个比较特殊的 cookie,当用

户请求服务器时,如果访问了 session,则服务器会创建一个名为 JSESSION,值

为获取到的 session(无论是获取到的还是新创建的)的 sessionId 的 cookie 对

象,并添加到 response 对象中,响应给客户端,有效时间为关闭浏览器。

所以 Session 的底层依赖 Cookie 来实现。

作为域对象

Session 用来表示一次会话,在一次会话中数据是可以共享的,这时 session

作为域对象存在,可以通过 setAttribute(name,value);方法向域对象中添加数据,

通过 getAttribute(name) 从域对象中获取数据,通过 removeAttribute(name)从域

对象中移除数据。

数据存储在 session 域对象中,当 session 对象不存在了,或者是两个不同

的 session 对 象时,数据也就不能共享了。这就不得不谈到 session 的生命周期。

Session的周期

当客户端第一次请求 servlet 并且操作 session 时,session 对象生成,

Tomcat 中 session 默认的存活时间为 30min,即你不操作界面的时间,一旦有

操作,session 会重新计时。

可以在 Tomcat 中的 web.xml 文件中进行修改生命周期。

当然除了以上的修改方式外,我们也可以在程序中自己设定 session 的生命

周期,通过 session.setMaxInactiveInterval(int);来设定 session 的最大不活动时间,

单位为秒。

HttpSession    session  =  rep.getSession();

Session.setMaxInactiveInterval(5);

当然我们也可以通过 getMaxInactiveInterval();方法来查看当前 Session 对

象的最大不活动时间。

或者我们也可以通过 session.invalidate();方法让 session 立刻失效。

Session.invalidate();

从前面的 JESSION 可知道,session 的底层依赖 cookie 实现,并且该 cookie

的有效时间为关闭浏览器,从而 session 在浏览器关闭时也相当于失效了(因为

没有 JSESSION 再与之对应)。

当非正常关闭服务器时,session 销毁;当正常关闭服务器时,Session 将被

序列化到磁盘上,在工作空间 work 目录下的 SESSION.ser 文件中,下次启动服

务时,自动加载到内存。

Session 失效则意味着此次会话结束,数据共享结束。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容