JavaWeb_HttpSession的生命周期
HttpSession的生命周期
- 1.什么时候创建 HttpSession 对象。
1)是否浏览器访问服务端的任何一个 JSP 或 Servlet,服务器都会立即创建一个 HttpSession 对象呢?
不一定。
①若当前的 JSP(或 Servlet) 是客户端访问的当前 WEB 应用的第一个资源,且 JSP 的 page 指定的 session 属性值为 false, 则服务器就不会为 JSP 创建一个 HttpSession 对象
②若当前 JSP 不是客户端访问的当前 WEB 应用的第一个资源,且其他页面已经创建一个 HttpSession 对象,则当前 JSP 页面会返回一个会话的 HttpSession 对象,而不会创建一个新的 HttpSession 对象。
2)对于 Serlvet 而言:若 Serlvet 是客户端访问的第一个 WEB 应用的资源,则只有调用了 request.getSession() 或 request.getSession(true) 才会创建 HttpSession 对象。 - 2.page 指令的 session=“false” 到底表示什么意思?
1)当前 JSP 页面禁用 session 隐含变量!但可以使用其他的显式的 HttpSession 对象。 - 3.在 Serlvet 中如何获取 HttpSession 对象?
1)request.getSession(boolean create):
①create 为 false,若没有和当前 JSP 页面关联的 HttpSession 对象,则返回 null;若有,则返回 true。
②create 为 true,一定返回一个 HttpSession 对象。若没有和当前 JSP 页面关联的 HttpSession 对象,则服务器创建一个新的 HttpSession 对象返回;若有,直接返回关联的。
2)request.getSession():等同于 request.getSession(true)。 - 4.什么时候销毁 HttpSession 对象?
1)直接调用 HttpSession 的 invalidate() 方法:该方法使 HttpSession 失效。
2)服务器卸载了当前 WEB 应用。
3)超出 HttpSession 的过期时间。
①设置 HttpSession 的过期时间:session.setMaxInactiveInterval(5); 单位为秒。
② 在 web.xml(Tomcat中的文件) 文件中设置 HttpSession 的过期时间:单位为分钟。
<session-config>
<session-timeout>30</session-timeout>
</session-config>
.
4)并不是关闭了浏览器就销毁了 HttpSession。