Jsp Jsp的四大域对象
| 作用范围 | 特殊之处 | ||
| pageContext | 当前jsp页面,当转发就失效 | 可以获取其他域对象中的值 | |
| request | 一次请求,转发公用request,重定向之前的request失效 | 注意重定向和转发 | |
| session | 一次会话 | 详情见下面 | |
| appliction(相当于java中的ServletContext) | 项目启动期间都有效,直到项目关闭 | 整个项目启动期间都有效 |
关于session的有效期: Session是会话技术关键节点之一,C第一次访问S,S端会产生一个唯一的值 key,并且在Session池中创建了一个Session,key就是他的唯一id,我们这里往session中setAttribute一个key 为name,值为xl的属性,这个Session的有效时长是可以设置的,默认tomcat中会给session一个默认时间30分钟,当然session也可以自己销毁,在响应头中 set-Cookie 属性上 放 上JSESSIONID=8C394A064383BDA072D63EE10CF481B1上,其实就是 session1.setMaxInactiveInterval(100); //设置session的有效时长 单位秒 session1.invalidate();//session自己销毁 response.addCookie(new Cookie(“JSESSIONID”, “8C394A064383BDA072D63EE10CF481B1”)); 也就是S在响应中给了C一个名为 JSESSIONID的cookie, 这个cookie的有效期呢,就要讨论cookie的保存形式了, cookie这边可以设置有效时间(单位秒) c.setMaxAge(1200); cookie的默认有效时长,是浏览器关闭就结束,这种cookie叫做会话cookie,还有一种叫做持久化cookie,设置cookie有效时长,会把cookie保存到硬盘上,关闭浏览器下一次再打开是cookie还存 Ok ! 继续session,我们之前说到S给了C一个名为 JSESSIONID的cookie,这个cookie是会话cookie,即关闭浏览器就会结束。这里有一个会话时长的概念,即用户访问浏览器直到用户关闭浏览器或者服务器关闭,这段时间成为一个会话。 C第二次访问 S,会把这个名为 JSESSIONID的cookie 带上,去访问S,S也会根据JSESSIONID找到指定的session,如果没有找到创建一个重复第一次访问的流程;找到了即可xxAttrbute(). 那么问题来了,虽然session的有效默认时长是30 分钟,但是 名为 JSESSIONID的cookie 是会话cookie,有效期 只有一个 会话时长,即 关闭浏览器 cookie失效,所以当关闭浏览器后,JSESSIONID的cookie 是会话cookie失效了,但之前session还是有效的,我们C再次访问S,及时Session池中有之前的session,但我们没有名为 JSESSIONID的cookie,所以我们只能再次走 第一次访问S的流程, 又重新创建产生一个唯一的值 key,并且在Session池中创建了一个Session,key就是他的唯一id。 所以之前的key 为name ,值为xl 的属性就去不到了,因为是两个不同的session了。