Cookie
1.Http协议Cookie(了解)
*Cookie是Http协议指定的,先由服务器保存Cookie到浏览器,再下次浏览器请求服务器时,会把上一次请求得到的Cookie返还给服务器
*由服务器创建保存到客户端浏览器的一个键值对,服务器保存Cookie的响应头:Set-Cookie:aaa=AAA
Set-Cookie:bbb=BBB
*当浏览器请求服务器是,会把该服务器保存的Cookie随请求发送给服务器。浏览器归还Cookie的请求头:Cookie:aaa=AAA;bbb=BBB
*Http协议规定(保证不给浏览器太大压力):
>1个Cookie最大4KB
>1个服务器最多1个浏览器保存20个Cookie
>1个浏览器最多可以保存300个Cookie
*浏览器大战:因为浏览器竞争很激烈,所以很多浏览器都会在一定范围内违反Http规定,但是也不会让一个Cookie为4GB!
Cookie是不能跨浏览器的
2.Cookie用途
*服务器使用Cookie来跟踪客户端状态;
*保存购物车(购物车中商品不能使用request保存,因为它是一个用户向浏览器发送的多个请求信息)
*显示上交登录名(也是一个用户多个请求)
3.JavaWeb中使用Cookie
*原始方法
>使用response发送Set-Cookie响应头
>使用request获取Cookie请求头
*便捷方式(精通)
>使用response.addCookie()
方法向浏览器保存Cookie
>使用request.getCookies()
方法获取浏览器归还的Cookie
方法展示:
创建一个a.jsp用来向客户端保存Cookie,b.jsp用来从客户端读取Cookie;
这是a.jsp:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>保存Cookie</title>
</head>
<body>
<h1 color="orange" align="center">这个jsp用来向浏览器保存Cookie</h1>
<%
Cookie cook1 = new Cookie("wangyue","5");
Cookie cook2 = new Cookie("jiangjiadong","6");
response.addCookie(cook1);
response.addCookie(cook2);
%>
</body>
</html>
这是b.jsp:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>这个jsp用来获取Cookie</title>
</head>
<body>
<h1 color="orange" align="center">这个jsp用来获取Cookie</h1><br/>
<%
Cookie[] cooks = request.getCookies();
for (Cookie cook:cooks
) {
out.println(cook.getName()+": "+cook.getValue() + "<br/>");
}
%>
</body>
</html>
当访问a.jsp的时候:
当访问b.jsp的时候:
4.Cookie详解
*Cookie不只有name和value两个属性
*Cookie的maxAge(掌握):Cookie的最大生命,即Cookie可保存的最大时长,以秒为单位,例如:cookie.setMaxAge(60)
表示这个cookie会被浏览器保存到硬盘一分钟
>maxAge>0:浏览器会把Cookie保存到客户机硬盘上,有效时长为这个值决定。
>maxAge<0:Cookie只在浏览器内存中存在,当用户关闭浏览器时,浏览器京城结束,同时Cookie也就死亡了。
>maxAge=0:浏览器会马上删除这个Cookie!
演示Cookie的最大生命:
首先在Servlet中设置:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>保存Cookie</title>
</head>
<body>
<h1 color="orange" align="center">这个jsp用来向浏览器保存Cookie</h1>
<%
Cookie cook1 = new Cookie("wangyue","5");
//设置Cookie最大生命为一小时
cook1.setMaxAge(60*60);
response.addCookie(cook1);
%>
</body>
</html>
打开设置查看Cookie的过期时间:
如果想删除这个Cookie,那么重新设置cook1.setMaxAge(0);
这个Cookie就会马上从浏览器中被删除!
*Cookie的path(了解)
>Cookie的path并不是设置这个Cookie在客户端的保存路径!!!
>Cookie的path由服务器创建Cookie时设置
>当浏览器访问服务器某个路径时,需要归还哪些Cookie给服务器呢,这由Cookie的path决定
>浏览器访问服务器的路径,如果包含某个Cookie的路径,那么就会归还这个Cookie。记住,访问路径是否包含Cookie路径!
当前有个b.jsp与a.jsp在同一个路径下,由于之前访问过了a.jsp,所以浏览器保存了一个Cookie,当访问b.jsp的时候,由于访问路径中包含了a.jsp的Cookie路径,所以将归还这个Cookie:
>例如:
<>aCookie.path = /my/; bCookie.path = /my/jsps/; cCookie.path = /my/jsps/cookie/;
<>访问/my/index.jsp
时,归还aCookie
<>访问/my/jsps/a.jsp
时,归还aCookie,bCookie
<>访问/my/jsps/cookie/b.jsp
时,归还aCookie,bCookie,cCookie
>Cookie的path默认值:当前访问路径的父路径。例如在访问/my/jsps/a.jsp时,响应的cookie,那么这个Cookie的默认path为/my/jsps/
*Cookie的domain(了解)
>domain用来指定Cookie的域名!当多个二级域中共享Cookie时才有用。
>例如:www.baidu.com、zhidao.baidu.com、news.baidu.com、tieba.baidu.com之间共享Cookie时可以使用domain
>设置domain为:cookie.setDomain(".baidu.com");
>设置path为:cookie.setPath("/");
这一步是共享Cookie所必须设置的,不能带项目的路径
本人是菜鸟一枚,当做学习笔记写博客。谢谢各路大咖驻足审阅