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个服务器最多向一个浏览器保存20个Cookie
> 1个浏览器最多保存300个Cookie
2、Cookie的用途
*服务器使用Cookie来跟踪客户端状态
*保存购物车
*显示上次登录名
************Cookie时不能跨浏览器的************
3、JavaWeb中使用Cookie
*原始方式(了解)
>使用response发送Set-Cookie响应头
>使用request获取Cookie请求头
*便捷方式(精通)
>使用response.addCookie()方法向浏览器保存Cookie
>使用reques.getCookies()方法获取浏览器归还的Cookie(如果没有返回Cookie,显示NULL)
案例:保存和获取Cookie
a.jsp
<body>
<h1>保存Cookie</h1>
<%
Cookie cookie1 = new Cookie("aaa", "AAA");
response.addCookie(cookie1);
Cookie cookie2 = new Cookie("bbb", "BBB");
response.addCookie(cookie2);
%>
</body>
b.jsp
<body>
<%
Cookie[] cookies = request.getCookies();
if (cookies != null) {
for (Cookie c : cookies) {
out.print(c.getName() + "=" + c.getValue() + "<br/>");
}
}
%>
</body>
4、Cookie详解
* Cookie不只有name和value两个属性
* Cookie的maxAge(掌握):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=/day01_1/; bCookie.path=/day01_1/jsps/;
cCookie.path=/day01_1/jsps/cookies/;
访问:/day01_1/index.jsp时,归还:aCookie
访问:/day01_1/jsps/index.jsp时,归还:aCookie、bCookie
访问:/day01_1/jsps/cookies/index.jsp时,归还:aCookie、bCookie、cCookie
> Cookie的path默认值:当前访问路径的父路径。例如:/day01_1/jsps/a.jsp时,响应的Cookie,那么这个Cookie的默认path为/day01_1/jsps/
* Cookie的domain(了解)
> domain用来指定Cookie的域名!当多个二级域中共享Cookie时才有用
>设置domain为:cookie.setDomain(“.Xxxxxxx”);
>设置path为:cookie.setPath(“/”);(必须为“/”)