Cookie
1. Http协议与Cookie
- Cookie是HTTP协议制定的!先由服务器保存Cookie到浏览器,再下次浏览器请求服务器时把上一次请求得到Cookie再归还给服务器
- 由服务器创建保存到客户端浏览器的一个键值对!服务器保存Cookie的响应头:Set-Cookie: aaa=AAA Set-Cookie: bbb=BBB
response.addHeader(“Set-Cookie”, “aaa=AAA”);response.addHeader(“Set-Cookie”, “bbb=BBB”);
- 当浏览器请求服务器时,会把该服务器保存的Cookie随请求发送给服务器。浏览器归还Cookie的请求头:Cookie: aaa=AAA; bbb=BBB
- Http协议规定:
1个Cookie最大4KB
1个服务器最多向1个浏览器保存20个Cookie
1个浏览器最多可以保存300个Cookie - 浏览器大战:因为浏览器竞争很激励,所以很多浏览器都会在一定范围内违反HTTP规定
2. Cookie的用途
- 服务器使用Cookie来跟踪客户端状态!
- 显示上次登录名(也是一个用户多个请求)
注意:Cookie是不能跨浏览器的!
3. JavaWeb中使用Cookie
- 原始方式:
使用response发送Set-Cookie响应头
使用request获取Cookie请求头 - 便捷方式:
使用repsonse.addCookie()方法向浏览器保存Cookie
使用request.getCookies()方法获取浏览器归还的Cookie
4. Cookie详解
- Cookie不只有name和value两个属性
- Cookie的maxAge:Cookie的最大生命,即Cookie可保存的最大时长。以秒为单位,例如:cookie.setMaxAge(60)表示这个Cookie会被浏览器保存到硬盘上60秒
maxAge>0:浏览器会把Cookie保存到客户机硬盘上,有效时长为maxAge的值决定。
maxAge<0:Cookie只在浏览器内存中存在,当用户关闭浏览器时,浏览器进程结束,同时Cookie也就死亡了。
maxAge=0:浏览器会马上删除这个Cookie! - Cookie的path:
Cookie的path并不是设置这个Cookie在客户端的保存路径!!!
Cookie的path由服务器创建Cookie时设置
当浏览器访问服务器某个路径时,需要归还哪些Cookie给服务器呢?这由Cookie的path决定。
浏览器访问服务器的路径,如果包含某个Cookie的路径,那么就会归还这个Cookie。
例如:
<> aCookie.path=/servletdemo/; bCookie.path=/servletdemo/jsps/; cCookie.path=/servletdemo/jsps/cookie/;
<> 访问:/servletdemo/index.jsp时,归还:aCookie
<> 访问:/servletdemo/jsps/a.jsp时,归还:aCookie