1.Http协议与Cookie(了解)
Cookie是Http协议制定的。先有服务器保存Cookie到浏览器,再下次浏览器请求服务器时把上一次请求得到的Cookie归还给服务器。
由服务器创建保存到客户端的一个键值对。服务器保存Cookie的响应头,使用response发送响应头: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
2.Cookie的用途
- 服务器使用Cookie来跟踪客户端状态。
- 保存购物车(购物车中的商品不能使用request域来保存,因为它是一个用户向服务器发送的多个请求信息)
- 显示上次登录用户名(并记住密码)
3.Java Web中使用Cookie
原始的方式:使用response发送Set-Cookie响应头。
使用request获取请求头。便捷方式:使用response.addCookie()方法向浏览器保存Cookie。
使用request.getCookies()方法获取浏览器归还的Cookie,返回的对象为Cookie数组。若没有Cookie则返回NULL。
4.Cookie详解
- Cookie不只有name和value两个属性。
- Cookie的maxAge:指Cookie的最大生命,即Cookie可保存在客户端中的最大时长,以秒为单位。
- maxAge>0:浏览器会把Cookie保存到客户端硬盘上,有效时长为maxAge的值决定,例如:cookie.setMaxAge(60)表示这个Cookie会被浏览器保存到硬盘上60秒。
- maxAge<0:Cookie只会在浏览器内存中存在,当用户关闭浏览器时浏览器进程结束,同时Cookie也就死亡了。
- maxAge=0:浏览器会马上删除这个Cookie。