设定cookie 过期时间:
Cookie coke = new Cookie("name", "pattern");
coke.setMaxAge(60);//s
response.addCookie(coke);
对于cookie的操作
设置:
Cookie cookie = new Cookie("key","value"); 创建一个cookie
cookie.setMaxAge(); 设置cookie的有效时间
cookie.setPath(uri); 设置cookie的路径
cookie.setDomain(".baidu.com");设置cookie的域(了解)
response.addCookie(cookie); 把cookie添加到响应中,这样才能发送给浏览器.可以添加多个cookie. (IE6.0一个网站只能记30个cookie,ie最多记录300个cookie.(但是发展到现在版本.数量提升了,具体没试过.Chrom3000个cookie))
浏览器发过来,取出cookie:
request.getCookies();
cookie的详情:
服务器使用 set-Cookie响应头 让浏览器记住一个数据(键值对) 响应头: Set-Cookie: name=tom
浏览器用Cookie请求头,告诉服务器一个键值对. 请求头:Cookie: name=tom
记录浏览历史:
// Cookie c = new Cookie("History");
Cookie[] cookieArray = request.getCookies();
String strs = request.getParameter("name");
Cookie temp = null;
if (cookieArray != null && cookieArray.length > 0) {
for (Cookie c : cookieArray) {
if (c.getName().equalsIgnoreCase("history")) {
temp = c;
break;
}
}
}
if (temp != null) {
String temps = (String) temp.getValue();
if (!temp.getValue().contains(strs)) {
temps += "," + strs;
}
Cookie newCookie = new Cookie("history", temps);
response.addCookie(newCookie);
request.setAttribute("history", temps);
} else {
Cookie newCookie = new Cookie("history", strs);
response.addCookie(newCookie);
}
request.getRequestDispatcher("/index2.jsp").forward(request, response);
Cookie coke = new Cookie("history", "");
coke.setMaxAge(0);
response.addCookie(coke);
request.getRequestDispatcher("/index2.jsp").forward(request, response);
<a href="/day11_jsp/CServlet?name=dell">Dell</a>
<br />
<a href="/day11_jsp/CServlet?name=Lenovo">lenovo</a>
<br />
<a href="/day11_jsp/CServlet?name=acer">Acer</a>
<br />
<%
String strs = (String) request.getAttribute("history");
%>
您浏览的历史是:<%=strs%><br/>
<a href="/day11_jsp/DServlet">删除Cookie</a>
例子:
1.显示上次访问时间
2.记录浏览历史.
Cookie细节
1.记多久
使用cookie.setMaxAge(int) ==> 该方法设置cookie有效时间
填写方法:
1.填写正数 --> 数字相当于秒 ==> 60 ==> 浏览器记住1分钟
2.填写0 --> 数字还是相当于秒 ==> 0 ==> 表示立即失效
3.填写-1 --> 这个数字表示只是临时记住 ==> 浏览器一旦关闭,那么cookie失效 ==> 浏览器一直不关闭==> 一直有效
通过上面的设置.需要删除一个cookie怎么办?
重新发送相同的cookie.设置cookie的有效时间为0.那么就相当于删除该cookie.
思考:如果我们不设置MaxAge,那么cookie默认有效时间是多长? ==> 默认有效时间是当浏览器关闭cookie删除也就是 相当于-1;
2.什么时候给我
研究什么时候发送cookie 实际上就是对cookie路径的研究.
访问http://localhost/day11-cookie/EServlet?name=HASEE这个路径时添加的cookie路径是==>/day11-cookie
路径默认会使用访问资源的当前路径作为cookie路径.
http://localhost/day11-cookie/ABC/BCD/AServlet ==> http://localhost/day11-cookie/ABC/BCD
路径在什么时候有效(会发送这个cookie呢?)?
浏览器记录了如下cookie
a /day11-cookie ==> 凡是/day11-cookie 路径下的所有子路径全都发送cookie
b /day11-cookie/ABC
c /day11-cookie/BCD
d /
有以下路径,在访问那些路径是会发送该cookie
http://localhost/day11-cookie/ABC/BCD/AServlet ==> 会发送a,b cookie
http://localhost/day11-cookie/BCD/BServlet ==> ac
http://localhost/day10/AServlet ==> d
在我们操作cookie时,除了默认赋予路径外,我们可不可以自己来设置cookie的路径呢?
使用cookie.setPath方法可以设置.
3.cookie的域问题(了解)
比如 baidu这个域上有多个主机,在这多个主机之间想共享一个cookie,那么这个cookie该如何设置?
music.baidu.com /day01
zhidao.baidu.com /day02
map.baidu.com / day03
cookie该如何设置呢? ==> 域 ".baidu.com" ==> 这么设置那么 以上三个地址都可以跟这个主机匹配.
==> 路径 "/" ==> 不管什么Context路径都会发送
4.cookie保存中文
因为传输中不支持中文.所以我们要先对中文进行编码
编码:URLEncoder.encode(str,charset);
浏览器还给我们时,我们再解码回来即可
解码:URLDecoder.decode(str,charset);