Cookie入门

1.Http协议与Cookie(了解)
  1. Cookie是Http协议制定的。先有服务器保存Cookie到浏览器,再下次浏览器请求服务器时把上一次请求得到的Cookie归还给服务器。

  2. 由服务器创建保存到客户端的一个键值对。服务器保存Cookie的响应头,使用response发送响应头:Set-Cookie:aaa=AAA;Set-Cookie:bbb=BBB;例如:
    response.addHeader("Set-Cookie","aaa=AAA");response.addHeader("Set-Cookie","bbb=BBB");

  3. 当浏览器请求服务器时,会把该服务器保存的Cookie随请求发送给服务器。浏览器归还Cookie的请求头:Cookie:aaa=AAA;bbb=BBB。多个键值对间用分号隔开。

  4. 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详解
  1. Cookie不只有name和value两个属性。
  2. Cookie的maxAge:指Cookie的最大生命,即Cookie可保存在客户端中的最大时长,以秒为单位。
  • maxAge>0:浏览器会把Cookie保存到客户端硬盘上,有效时长为maxAge的值决定,例如:cookie.setMaxAge(60)表示这个Cookie会被浏览器保存到硬盘上60秒。
  • maxAge<0:Cookie只会在浏览器内存中存在,当用户关闭浏览器时浏览器进程结束,同时Cookie也就死亡了。
  • maxAge=0:浏览器会马上删除这个Cookie。

你可能感兴趣的:(Cookie入门)