- Http协议与Cookie(了解)
- Cookie是HTTP协议制定的!先由服务器保存Cookie到浏览器,再下次浏览器请求服务器时把上一次请求得到Cookie再归还给服务器
- Http协议规定(保证不给浏览器太大压力):
1个Cookie最大4KB
1个服务器最多向1个浏览器保存20个Cookie
1个浏览器最多可以保存300个Cookie - 浏览器大战:因为浏览器竞争很激励,所以很多浏览器都会在一定范围内违反HTTP规定,但也不会让一个Cookie为4GB!
- Cookie的用途
- 服务器使用Cookie来跟踪客户端状态!
- 保存购物车(购物车中的商品不能使用request保存,因为它是一个用户向服务器发送的多个请求信息)
- 显示上次登录名(也是一个用户多个请求)
Cookie是不能跨浏览器的!*
- JavaWeb中使用Cookie
- 原始方式(了解):
使用response发送Set-Cookie响应头
使用request获取Cookie请求头 - 便捷方式(精通):
使用repsonse.addCookie()方法向浏览器保存Cookie
使用request.getCookies()方法获取浏览器归还的Cookie
<%
response.addCookie(new Cookie("name","xxx"));
response.addCookie(new Cookie("name","xxxv2"));//会覆盖上一个
response.addCookie(new Cookie("password","123"));
%>
- Cookie详解
- Cookie的maxAge(掌握):Cookie的最大生命,即Cookie可保存的最大时长。以秒为单位,例如:cookie.setMaxAge(60)表示这个Cookie会被浏览器保存到硬盘上60秒
maxAge>0:浏览器会把Cookie保存到客户机硬盘上,有效时长为maxAge的值决定。
maxAge<0:Cookie只在浏览器内存中存在,当用户关闭浏览器时,浏览器进程结束,同时Cookie也就死亡了。
maxAge=0:浏览器会马上删除这个Cookie!
可以利用new Cookie("name","value").setmaxAge(0)
来删除旧cookie
默认为maxAge<0
- Cookie的path:
Cookie的path由服务器创建Cookie时设置
当浏览器访问服务器某个路径时,需要归还哪些Cookie给服务器呢?这由Cookie的path决定。
浏览器访问服务器的路径,如果包含某个Cookie的路径,那么就会归还这个Cookie。
例如:
<>
aCookie.path=/day11_1/;
bCookie.path=/day11_1/jsps/;
cCookie.path=/day11_1/jsps/cookie/;
<> 访问:/day11_1/index.jsp时,归还:aCookie
<> 访问:/day11_1/jsps/a.jsp时,归还:aCookie、bCookie
<> 访问:/day11_1/jsps/cookie/b.jsp时,归还:aCookie、bCookie、cCookie
Cookie的path默认值:当前访问路径的父路径。例如在访问/day11_1/jsps/a.jsp时,响应的cookie,那么这个cookie的默认path为/day11_1/jsps/ - Cookie的domain(跨域名cookie)
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中不能存在中文!!!
// 保存
Cookie c = new Cookie(“username”, URLEncoder.encode(“张三”, “utf-8”));//出错!
response.addCookie©;
// 获取
Cookie[] cs = request.getCookies();
if(cs != null) {
for(Cookie c : cs){
if("username".equals(c.getName())) {
String username = c.getValue();
username = URLDecoder.decode(username, "utf-8");
}
}
}