Day37 Cookie&Seesion会话
1.1.1 什么是cookie
当用户通过浏览器访问Web服务器时,服务器会给客户端发送一些信息,这些信息都保存在Cookie中。这样,当该浏览器再次访问服务器时,都会在请求头中将Cookie发送给服务器,方便服务器对浏览器做出正确的响应。
1.1.2
1.1.3
1.1.4
1.1.5 会话技术
l 概念:
用户打开浏览器,点击多个超链接访问服务器的web资源,然后关闭浏览器,整个过程称之为一次会话.(打电话)
l 作用:
每个用户与服务器进行交互过程中,产生各自的数据,程序想要将这个数据进行保存,就需要使用会话技术.
一次会话中多次请求之间共享数据
1.1.6 Cookie执行原理(工作流程):
浏览器访问服务器,服务器产生键值对的形式(cookie),通过响应(响应头 set-cookie)返回给浏览器,cookie保存在浏览器上,下次访问的服务器时候,根据一定的规则携带不同的cookie,通过请求(请求头 cookie)携带,服务器就可以拿到这些cookie
l Cookie和缓存的区别(了解).
n 缓存是浏览器自动进行处理的
n Cookie是服务器要求浏览器保存的数据
1.1.7 Cookie的API
方法名 |
描述 |
getName() |
获得cookie名称。 |
getValue() |
获得cookie的值。 |
setMaxAge(int expiry) |
设置cookie的有效时间。 l 如果没有设置,cookie只缓存浏览器缓存中,浏览器关闭,cookie删除。 l 如果设置有效时间,在时间范围内,cookie被写入到浏览器端,关闭浏览器下次访问仍可获得,直到过期。 |
setPath(java.lang.String uri) |
设置cookie允许被访问的路径。设置的路径,以及子路径都被允许访问。 l 例如:setPath("/web/a/b"); http://localhost:8080/web/a/b/oneServlet,可访问(当前路径) http://localhost:8080/web/a/b/c/oneServlet,可访问(子路径) http://localhost:8080/web/a/c/oneServlet,不允许访问(无关路径) l 常见设置:setPath(“/”) ,当前tomcat下的所有的web项目都可以访问 |
1.1.7.1 Session概念
Session是服务器端会话技术
提供一种方式,跨多个页面请求或对 Web 站点的多次访问标识用户并存储有关该用户的信息(一个会话多次请求之间共享数据)
一次会话中,如果需要数据保存到服务器端.创建一个Session对象用来保存数据.(一次会话对应一个Session对象)
1.1.7.2 Session执行原理
l 生命周期(了解)
Session对象创建到销毁的过程
n 创建
u 创建时间:第一次调用request.getSession();
u 创建者:tomcat服务器
n 销毁
u 超时
默认Session的有效时间为30分钟.当浏览器关闭时,会话级别的cookie就自动销毁了,无法获得sessionid,就不能获得服务器端的Session对象,但服务器端的Session依然存在.
Tomcat/conf/web.xml
<session-config>
<session-timeout>30</session-timeout>
</session-config>
u 服务器非正常关闭
u 手动调用方法
session.invalidate(); 实际开发中不用
l Session的API
n 保存数据
u setAttribute(String name,Object obj)
n 获得数据
u getAttribute(String name);
n 删除数据
u removeAttribute(String name)
1.1 小结:Cookie和Session的选取
* Cookie是有大小和个数的限制的.Session存到服务器端的技术,没有大小和个数的限制.
Cookie常用于:登录”记住我”, ”浏览记录”
* Cookie相对于Session来讲不安全.
Session常用于: 用户登录
数据安全的信息保存Session,不安全的保存到Cookie
1.2 Servlet三个作用域
l ServletContext针对一个WEB项目
n 创建:服务器启动时,为每一个项目创建一个
n 销毁:服务器关闭或者项目被移除时
n 作用域:整个web项目共享,数据永久共享.
l HttpSession针对一个会话,一个会话多次请求之间共享数据
n 创建:第一次使用getSession()
n 销毁
u 超时
u 手动关闭
u 服务器非正常关闭
n 作用域: 一次会话*享数据(多次请求多次响应中,多个servlet之间共享数据)
l HttpServletRequest针对一次请求
n 创建:客户端向服务器端发送请求.使用该对象保存数据,一次请求中数据有效
n 销毁:服务器开始响应时
n 作用域:一次请求中多个servlet之间共享数据,用于请求转发
l 3个作用范围?
servletConetext > Session > Request
实际开发中原则: 能小不大
l 通用API
n 保存数据
u setAttribute(String name,Object obj)
n 获得数据
u getAttribute(String name);
n 删除数据
u removeAttribute(String name)
Session会话机制:
Session基于Cookie的工作流程:
(1)当用户通过浏览器进程第一次请求一个支持会话的资源时,Servlet容器会为这个会话创建一个HttpSession对象,并为其分配一个唯一的ID,当前会话就此开始。
(2)把这个唯一的ID以name为JSESSIONID的Cookie形式添加到响应中,返回给客户端保存。(当Cookie被禁用时,使用URL重写机制,在URL后添加;jsessionid=XXX以传输HttpSession对象标识)
(3)当浏览器进程再次请求这个支持会话的资源时,会在请求头中加上一直保持着的JSESSIONID,Servlet容器会在HTTP请求头中自动查找这个Cookie(也可以通过HttpSession.getId()方法主动获取),如果找到,就取出对应HttpSession对象(其实用户第一次访问,也会进行相同的查询,因为查询不到,才会执行创建操作)。