HttpSession会话状态的生命周期

[转]

HttpSession会话状态的生命周期
浏览器访问服务器时,服务器会创建一个session对象(有一个sessionId)。服务器在默认的情况下,会将sessionId以cookie的机制发送给浏览器。当浏览器再次访问服务器时,会将sessionId发送给服务器,服务器依据sessionId就可以找到对应的session对象。服务器以此方式管理用户的状态。

        获取session对象的方式有两种:
一、HttpSession session = request.getSession(boolean flag);当flag = true时,服务器会先查看请求中是否包含sessionId,如果有,则依据sessionId去查找对应的session对象,如果找到返回该对象。如果找不到,则会创建一个新的session对象。当flag = false时,服务器会先查看请求中是否包含sessionId,如果没有,返回null。如果有返回sessionId对应的session对象。
二、HttpSession session = request.getSession()与方式一中request.getSession(true)等价。Session生命周期,Servlet容器从创建Session对象到销毁的过程。Servlet容器会依据Session对象设置的存活时间,在达到Session时间后将Session对象销毁。

        设置Session存活时间的方式有三种:
一、session.setMaxInactiveInterval(interval)方法体内的参数interval为秒。
二、web.xml里配置如下信息

        <session-config>

              <session-timeout>时间长度(单位为分钟)</session-timeout>

</session-config>
三、在tomcat/conf/server.xml中定义defaultSessionTimeOut=时间长度(分钟)

三种方式中当值为-1时,session永不失效。三种方式的优先级为:第一种方式>第二种方式>第三种方式

————————————————
版权声明:本文为CSDN博主「zhangjinpeng66」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/zhangjinpeng66/article/details/10449979

posted @ 2019-11-15 21:35  主的羊  阅读(1486)  评论(0编辑  收藏  举报