1、http协议与Cookie
Cookie是HTTP协议制定的,先由服务器保存Cookie到浏览器,再下次浏览器请求服务器时把上一次请求得到Cookie再归还给服务器。由服务器创建保存到客户端浏览器的一个键值对,服务器保存Cookie的响应头:Set-Cookie:aaa=AAA Set-Cookie:bbb=BBB
–>response.addHeader(“Set-Cookie”,“aaa=AAA”);reaponse.addHeader(“Set-Cookie”,“bbb=BBB”);
当浏览器请求服务器时,会把该服务器保存Cookie随请求发送给服务器,浏览器归还的请求头:Cookie:aaa=AAA; bbb=BBB
http协议规定(保证不给浏览器太大压力)
–>1个Cookie最大4KB
–>1个服务器最多向1个浏览器保存20个cookie
–>1个浏览器最多可以保存300个cookie
浏览器大战:因为浏览器竞争很激烈,所以很多浏览器都会在一起范围内违反http规定,但也不会让一个cookie为4GB
2、cookie的用途
–>服务器使用cookie来跟踪客户端状态。
–>保存购物车(购物车中的商品不能使用request保存,因为它是一个用户向服务器发送的多个请求信息)
–>显示上次登录名
–>Cookie是不能跨浏览器的
3、JavaWeb中使用cookie
–>原始方式(了解)
–>使用response发送Set-Cookie响应头
–>使用request获取Cookie1请求头
–>便捷方式(精通)
–>使用response.addCookie()方法向浏览器保存Cookie
–>使用request.getCookie()方法获取浏览器归还的Cookie
4、Cookie详解
–>Cookie不只有name和value两个属性
Cookie的maxAge(掌握):Cookie的最大生命,即Cookie可保存的最长时长,以秒为单位,例如:cookie.setMaxAge(60)表示这个Cookie会被浏览器保存到硬盘
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=/项目名/;bCookie.path=/项目名/jsp目录/;cCookie.path=/项目名/jsp目录/.jsp文件名
访问:/项目名/index.jsp,归还aCookie
访问:/项目名/jsp目录/a.jsp时,归还:aCookie、bCookie
访问:/项目名/jsp目录/cookie/b.jsp时,归还:aCookie、bCookie、cCookie
Cookie的path默认值:当前访问路径的父路径,例如在访问/项目名/jsp目录/a.jsp时,响应的cookie,那么这个cookie的默认path为/项目名/jsp目录/
Cookie的domain(了解)
domain用来指定Cookie的域名,当多个二级域中共享cookie时才有用