最近做了个系统,其中涉及到对Cookie的操作。当用户登录时,设置一些数据到Cookie中,用户登出系统的时候删除写入浏览器中的对应Cookie。
问题就出在登出系统时,在firebug中看到需要删除的Cookie并没有删除掉。

最后经过自己的debug,终于找到了问题的所在。

直接上代码:

登录时写Cookie:

  1. public void setLoginIDCookie1(HttpServletResponse response, String value) {
  2. Cookie cookie = new Cookie(loginIdCookieKey, value);
  3. // 设置cookie的域,如果不设置该属性将不能够写入cookie
  4. if (!StringUtils.isBlank(domain)) {
  5. cookie.setDomain(domain);
  6. }
  7. // 设置cookie的路径,这个路径即改工程下都可以访问该cookie 如果不设置路径,那么只有设置该cookie的路径及其子路径可以访问
  8. if (!StringUtils.isBlank(path)) {
  9. cookie.setPath(path);
  10. }
  11. // 设置cookie的过期时间(单位秒)
  12. if (expiry > 0) {
  13. cookie.setMaxAge(expiry);
  14. }
  15. response.addCookie(cookie);
  16. }
  1. public void setLoginIDCookie1(HttpServletResponse response, String value) {
  2. Cookie cookie = new Cookie(loginIdCookieKey, value);
  3. // 设置cookie的域,如果不设置该属性将不能够写入cookie
  4. if (!StringUtils.isBlank(domain)) {
  5. cookie.setDomain(domain);
  6. }
  7. // 设置cookie的路径,这个路径即改工程下都可以访问该cookie 如果不设置路径,那么只有设置该cookie的路径及其子路径可以访问
  8. if (!StringUtils.isBlank(path)) {
  9. cookie.setPath(path);
  10. }
  11. // 设置cookie的过期时间(单位秒)
  12. if (expiry > 0) {
  13. cookie.setMaxAge(expiry);
  14. }
  15. response.addCookie(cookie);
  16. }


登出时,删除Cookie:

  1. public void deleteLoginCookies(HttpServletRequest request, HttpServletResponse response) {
  2. Cookie[] cookies = request.getCookies();
  3. if (cookies != null && cookies.length >0) {
  4. // 遍历浏览器发送到服务器端的所有Cookie,找到自己设置的Cookie
  5. for (Cookie cookie : cookies) {
  6. String cookieName = cookie.getName();
  7. if (cookieName.equals(loginIdCookieKey)) {
  8. // 设置Cookie立即失效
  9. cookie.setMaxAge(0);
  10. /**
  11. * 删除Cookie时,只设置maxAge=0将不能够从浏览器中删除cookie,
  12. * 因为一个Cookie应当属于一个path与domain,所以删除时,Cookie的这两个属性也必须设置。
  13. *
  14. * 误区:刚开始时,我没有发现客户端发送到服务器端的cookie的path与domain值为空这个问题。
  15. * 因为在登陆系统时,我设置了Cookie的path与domain属性的值,就误认为每次客户端请求时,都会把Cookie的
  16. * 这两个属性也提交到服务器端,但系统并没有把path与domain提交到服务器端(提交过来的只有Cookie的key,value值)。
  17. */
  18. // 重点是这里1,必须设置domain属性的值
  19. cookie.setDomain(domain);
  20. // 重点是这里2,必须设置path属性的值
  21. cookie.setPath(path);
  22. response.addCookie(cookie);
  23. }
  24. }
  25. }
  26. }
  1. public void deleteLoginCookies(HttpServletRequest request, HttpServletResponse response) {
  2. Cookie[] cookies = request.getCookies();
  3. if (cookies != null && cookies.length > 0) {
  4. // 遍历浏览器发送到服务器端的所有Cookie,找到自己设置的Cookie
  5. for (Cookie cookie : cookies) {
  6. String cookieName = cookie.getName();
  7. if (cookieName.equals(loginIdCookieKey)) {
  8. // 设置Cookie立即失效
  9. cookie.setMaxAge(0);
  10. /**
  11. * 删除Cookie时,只设置maxAge=0将不能够从浏览器中删除cookie,
  12. * 因为一个Cookie应当属于一个path与domain,所以删除时,Cookie的这两个属性也必须设置。
  13. *
  14. * 误区:刚开始时,我没有发现客户端发送到服务器端的cookie的path与domain值为空这个问题。
  15. * 因为在登陆系统时,我设置了Cookie的path与domain属性的值,就误认为每次客户端请求时,都会把Cookie的
  16. * 这两个属性也提交到服务器端,但系统并没有把path与domain提交到服务器端(提交过来的只有Cookie的key,value值)。
  17. */
  18. // 重点是这里1,必须设置domain属性的值
  19. cookie.setDomain(domain);
  20. // 重点是这里2,必须设置path属性的值
  21. cookie.setPath(path);
  22. response.addCookie(cookie);
  23. }
  24. }
  25. }
  26. }

关于设置了setMaxAge(0)而浏览器未成功删除Cookie的注意事项的更多相关文章

  1. 浏览器未安装flash插件,js判断直接去官网安装

    近期做了个活动页,里面根据需求插入了阿里云的视频,常见的浏览器都支持包括低版本的. 由于浏览器的更新换代很多版本放弃了flash的插件安装,火狐就是其中之一. 未安装flash的浏览器如果打开这个链接 ...

  2. 记录修改安卓5.0系统浏览器UI遇到的部分问题

    碎碎念 今年七月份本科毕业后入职一家会议平板公司,经过一个一个多月的咸鱼培训轮岗生活,接手了几个小任务,本次记录一下其中一个任务:修改安卓5.0系统浏览器UI.刚接到任务的时候,本以为是很简单的一个任 ...

  3. 给div设置background-color: rgba(0, 0, 0, 0.2)属性,并加了css3动画--opacity动画淡出动画,之后div子元素的字体会抖一下

    问题:给div设置background-color: rgba(0, 0, 0, 0.2)属性,并加了css3动画--opacity动画淡出动画,之后div子元素的字体会抖一下: 解决:animati ...

  4. jquery 设置checked="checked"无效,radio未选中。。

    jquery 设置checked="checked"无效,radio未选中.. 最好还是使用.prop(),在jQuery1.6版本之前.attr存在一些bug.在1.6之后它会自 ...

  5. js设置cookie过期及清除浏览器对应名称的cookie

    js设置cookie过期也就相当于清除浏览器对应名称的cookie的例子. 代码: function ClearCookie() {  var expires = new Date();  expir ...

  6. ListView列宽自适应,设置ListView.Column[0].Width := -1;

    使用TListView列表显示内容,如果列内容过长,就会显示成‘XXX…’形式,此时如果双击列标题,列宽将变为自适应.用代码设置如下: 1.设置ListView.Column[0].Width := ...

  7. 快速解决设置Android 23.0以上版本对SD卡的读写权限无效的问题

    快速解决设置Android 23.0以上版本对SD卡的读写权限无效的问题 转 https://www.jb51.net/article/144939.htm 今天小编就为大家分享一篇快速解决设置And ...

  8. Retrofit2.0 ,OkHttp3完美同步持久Cookie实现免登录(二)

    原文出自csdn: http://blog.csdn.net/sk719887916/article/details/51700659: 通过对Retrofit2.0的<Retrofit 2.0 ...

  9. PHP中设置、使用、删除Cookie方法

    1.设置Cookie PHP用SetCookie函数来设置Cookie.必须注意的一点是:Cookie是HTTP协议头的一部分,用于浏览器和服务器之间传递信息,所以必须在任何属于HTML文件本身的内容 ...

随机推荐

  1. mysql索引之五:多列索引

    索引的三星原则 1.索引将相关的记录放到一起,则获得一星 2.如果索引中的数据顺序和查找中的排列顺序一致则获得二星 3.如果索引中的列包含了查询中的需要的全部列则获得三星 多列索引 1.1.多个单列索 ...

  2. mysql索引之一:索引基础(B-Tree索引、哈希索引、聚簇索引、全文(Full-text)索引区别)(唯一索引、最左前缀索引、前缀索引、多列索引)

    没有索引时mysql是如何查询到数据的 索引对查询的速度有着至关重要的影响,理解索引也是进行数据库性能调优的起点.考虑如下情况,假设数据库中一个表有10^6条记录,DBMS的页面大小为4K,并存储10 ...

  3. 嵌入式Linux驱动和固件有何区别?供应商是如何用固件压缩成本的?

    作为一个驱动开发者, 你可能发现你面对一个设备必须在它能支持工作前下载固件到它里面. 硬件市场的许多地方的竞争是如此得强烈, 以至于甚至一点用作设备控制固件的 EEPROM 的成本制造商都不愿意花费. ...

  4. setTimeout和setInterval的unref()和ref()用法

    var testFunction=function(){ console.log("guoyansi"); } var timer=setInterval(testFunction ...

  5. IOCP的缓冲区

    IOCP的缓冲区: 应用程序的缓冲区 套接字的缓冲区 TCP的缓冲区 两个会造成WSAENOBUFS错误的原因: 锁定页面达到上限 非分页页面达到上限

  6. CDN之多边缘节点负载均衡--学习笔记

    一.剧情 剧情是这样的,本次的多边缘节点负载均衡实验,1个LVS四层负载均衡集群和1个Nginx为反向代理的七层负载均衡集群,由Bind dns解析作为 主负载均衡服务器,调度两个集群,中间层有一台W ...

  7. 使用国内源部署ceph

    由于网络方面的原因,Ceph的部署经常受到干扰,通常为了加速部署,基本上大家都是将Ceph的源同步到本地进行安装.根据Ceph中国社区的统计,当前已经有国内的网站定期将Ceph安装源同步,极大的方便了 ...

  8. C语言和C++中的字符串(string)

    知识内容: 1.C\C++字符串简述 2.C字符串相关操作 3.C++ string类相关操作 一.C\C++字符串简述 1.C语言字符串 C语言字符串是字符的数组.单字节字符串顺序存放各个字符串,并 ...

  9. Tkinter画布-Canvas

    Python - Tkinter画布-Canvas: Canvas是一个长方形的面积,图画或其他复杂的布局.可以放置在画布上的图形,文字,部件,或是帧 Canvas是一个长方形的面积,图画或其他复杂的 ...

  10. oringin 画图

    oringin做图输出矢量图方法: 右击图区,选择copy page 在Word文档中直接粘贴即可 oringin做图调整图边距: tool->option->page->margi ...