最近,学习注意力老是不集中,但是昨晚跟同学谈谈心了后,慢慢地状态回来了,是时候拼尽全力去争取自己想要的东西。有些事、人过了就过了,不再去叹息,也不回头。好的,接着上一章继续我们的故事:
(一)重定向
在重定向的情况下,总共对Web资源进行了两次请求。
第二次的request对象再也找不到第一次request域对象的请求内容了,因为整个请求过程完成后就会被清空。
那么如何才能重新获得第一次request域对象的内容呢?
servletContext域对象的存在使得这个问题迎刃而解
1.在重定向的情况下,request域对象不能用了,因此我们用ServletContext域对象替代。
ServletContext 域对象有如下特点:
(1)ServletContext域对象的创建时期:在进行Web应用部署时,启动服务器就创建了。即,在第一次访问前ServletContext就创建完毕。
(2)Tomcat中的每一个Web应用,都自己专属的ServletContext域对象。
(3)一个Web应用下的所有web资源,全部共享自己所在区域的ServletContext域对象。
(4)由Servlet引擎负责创建ServletContext域对象。
(5)ServletContext域对象的销毁时期:当进行Web服务器停止或者重新部署应用时,原有的ServletContext域对象就被销毁掉。
注意:关闭浏览器并不会使得ServletContext域对象被销毁
2.ServletContext域对象的生命周期图
(二)Cookie
会话:用户打开一个浏览器,浏览点击了多个链接网址,访问多个web资源,直到关闭浏览器的整个过程,称之为一个会话过程。
在用户浏览网页的过程中,难免会有些数据产生是需要服务器获得的。客户端和服务器之间会进行数据交互,在这里我们有两种保存会话数据的技术,各有各的优缺点。
1.什么是Cookie?
Cookie是客户端技术,创建于服务端。服务器把每个用户的数据以cookie的形式写给用户各自的浏览器。当用户使用该浏览器去访问服务端的时候就会带着自己的cookie去访问,从而达到了数据有记录且处理的是用户各自的数据的目的。
方法:服务器向用户的浏览器写入set-cookie响应头
- 一个网站的cookie对应着一个文件,有着多个cookie。如果一个文件被写满了,则可以写入另外一个文件中。
- 一个浏览器可存入多个网站的cookie,每个网站只能寻找对应的cookie。
如果cookie的缓存时间过期了,就算在浏览器的缓存区中,服务器也再也读取不到的。
注意:cookie在代码中需要设置缓存时间,不然,执行完整个会话过程,不会有cookie的存在。
//设置cookie的有效时间,单位为秒
cookie.setMaxAge(1*24*60*60);
cookie.setPath(request.getContextPath());//获取缓存的网站,请求的网站
//将cookie输出给浏览器
response.addCookie(cookie);
4.cookie的细节
(1)cookie的弊端:只能以key:value的形式进行存储,若有多个cookie时会显得很繁琐、不实用。
(2)一个cookie只能标识一种信息,它至少含有一个能够标识该信息的标识名称和设置值。
(3)一个Web站点(百度、新浪服务器)可以给一个Web浏览器多个cookie。一个Web浏览器可以接收多个Web站点的cookie。
5.总结:浏览器存放cookie的数量是有限制的。如果创建了一个cookie,并将它发送到浏览器,默认的情况下,它是一个会话级别的cookie(即存储在浏览器的内存中)。当用户退出浏览器时,cookie即销毁。若想cookie有段存活时间,则需要设置缓存时间
(三)HttpSession
1.什么是HttpSession?
HttpSession是一种服务端技术,创建于服务端,存储在服务端。每个浏览器都有在服务端独自共享的、属于自己的HttpSession。
- 在Web开发过程中,服务器都会为每个用户的浏览器创建一个会话对象(session域对象),一个浏览器独占一个session对象(通常的,默认情况下)。
- session对象有服务器创建,API:
request.getSession();//创建得到session对象
2.session域对象
(1)API:request.getSession();
有两层意思:
- 如果服务器没有与客户端相对应的session,则创建session对象
- 如果已有,表示获取原有的session。
(2)同样,有着是域对象的常用方法。
setAttribute;
addAttribute;
getAttribute;
removeAttribute;
(3)不管在转发或者是重定向的情况下,多个servlet共享同一个HttpSession对象
3.域对象的创建、销毁时刻
4.Session运行原理
为什么除了首次请求之外每次请求都会发送这个cookie呢(在这里确切地说是发送这个jsessionid)?
事实上当用户访问服务器的时候会为每一个用户开启一个session,浏览器是怎么判断这个session到底是属于哪个用户呢?jsessionid的作用就体现出来了:jsessionid就是用来判断当前用户对应于哪个session。换句话说服务器识别session的方法是通过jsessionid来告诉服务器该客户端的session在内存的什么地方。
事实上jsessionid ==request.getSession().getId()