标签:
首先要了解cookie必须得先了解http协议,,Cookie是http协议指定的,先由服务器保存cookie到浏览器,在下次浏览器请求服务器时把上次请求得到的cookie归还给服务器,cookie以键值对的形式保存在本地的缓存中.
注意,不同浏览器还是略有差异,不是所有浏览器都老老实实的遵守这个规定.
我们在a.jsp中保存一个coookie,然后在b.jsp中获取到这个cookie,并遍历出来(因为比较简单,这里只提供代码部分):
//a.jsp的body部分 <% Cookie cookie1=new Cookie("name","wang"); response.addCookie(cookie1); Cookie cookie2=new Cookie("password","123"); response.addCookie(cookie2); %> //b.jsp的body部分 <% Cookie[] cookie1=request.getCookies(); for(Cookie c:cookie1){ out.print(c.getName()+":"+c.getValue()+"<br>"); } %>
当服务器创建Cookie对象后,可以调用setMaxAge()方法设置Cookie的最大生命。
设置cookie的路径需要用到cookie.setPath(String path)方法.例如:cookie.setPath("/cookie1/a");
如果没有设置cookie的路径,那么cookie的路径默认为是当前资源所在的路径,例如:
了解完了cookie的path,那么问题来了,它的用处是什么呢?这玩意有毛用?
假设现在有WEB应用A,向客户端发送了10个Cookie,这就说明客户端无论访问应用A的哪个Servlet都会把这10个Cookie包含在请求中!这是不科学的,因为也许只有AServlet需要读取请求中的Cookie,而其他Servlet根本就不会获取请求中的Cookie。这说明客户端浏览器有时发送这些Cookie是多余的,这时候就可以通过设置Cookie的path来指定浏览器在访问什么样的路径时,包含什么样的Cookie。
请求路径如果包含了Cookie路径,那么会在请求中会包含这个Cookie,否则请求中不会包含这个Cookie。如果某cookie的路径是/myCookieDemo/cookie1;当我们访问http://localhost:8080/myCookieDemo/index.jsp时,请求头中就不会携带这个cookie,而如果访问的是http://localhost:8080/myCookieDemo/cookie1/index.jsp时,请求头中就会包含这个cookie,这个页面也就能获取到此cookie中保存的数据.
Cookie的name和value都是不能保存中文的,但可以先把中文转换成URL编码,然后在保存到Cookie的name和value中。下面是代码Demo:
String name = "姓名"; String value = "张三"; name = URLEncoder.encode(name, "utf-8"); value = URLEncoder.encode(value, "utf-8"); Cookie c = new Cookie(name, value); response.addCookie(c); //在获取Cookie时,再使用URL解码即可。 Cookie[] cs = request.getCookies(); if(cs != null) { for(Cookie c : cs) { String name = URLDecoder.decode(c.getName(), "utf-8"); String value = URLDecoder.decode(c.getValue(), "utf-8"); System.out.println(name + "=" + value); } }
标签:
原文地址:http://www.cnblogs.com/fingerboy/p/5180598.html