java操作cookie示例(删除cookie)
1.设置cookie
cookie cookie = new cookie("key", "value");
cookie.setmaxage(60);
设置60秒生存期,如果设置为负值的话,则为浏览器进程cookie(内存中保存),关闭浏览器就失效。
cookie.setpath("/test/test2");
设置cookie路径,不设置的话为当前路径(对于servlet来说为request.getcontextpath() + web.xml里配置的该servlet的url-pattern路径部分)
response.addcookie(cookie);
2.读取cookie
该方法可以读取当前路径以及“直接父路径”的所有cookie对象,如果没有任何cookie的话,则返回null
cookie[] cookies = request.getcookies();
3.删除cookie
cookie cookie = new cookie("key", null);
cookie.setmaxage(0);
设置为0为立即删除该cookie
cookie.setpath("/test/test2");
删除指定路径上的cookie,不设置该路径,默认为删除当前路径cookie
response.addcookie(cookie);
4.注意:假设路径结构如下
test/test2/test345/test555/test666
a.相同键名的cookie(值可以相同或不同)可以存在于不同的路径下。
b.删除时,如果当前路径下没有键为"key"的cookie,则查询全部父路径,检索到就执行删除操作(每次只能删除一个与自己最近的父路径cookie)
ff.必须指定与设定cookie时使用的相同路径来删除改cookie,而且cookie的键名不论大写、小写或大小混合都要指定路径。
ie.键名小写时,如果当前路径为/test/test2,如果找不到再向上查询/test、/test555、/test345,如果还找不到就查询/。(/test555/test666不查询)
键名大小写混合或大写时,不指定路径则默认删除当前路径,并且不向上查询。
c.读取cookie时只能读取直接父路径的cookie。
如果当前路径为/test/test2,要读取的键为"key"。当前路径读取后,还要读取/test,/test读取后,还要读取/
d.在做java的web项目时,由于一般的web服务器(如tomcat或jetty)都用context来管理不同的webapplication,这样对于每个context有不同的path,
在一个server中有多个webapplication时要特别小心,不要设置path为/的cookie,容易误操作。(当然前提是域名相同)
上一篇: java使用ftp上传文件示例分享
下一篇: java md5工具类分享