关于设置了setMaxAge(0)而浏览器未成功删除Cookie的注意事项
最近做了个系统,其中涉及到对Cookie的操作。当用户登录时,设置一些数据到Cookie中,用户登出系统的时候删除写入浏览器中的对应Cookie。
问题就出在登出系统时,在firebug中看到需要删除的Cookie并没有删除掉。
最后经过自己的debug,终于找到了问题的所在。
直接上代码:
登录时写Cookie:
- public void setLoginIDCookie1(HttpServletResponse response, String value) {
- Cookie cookie = new Cookie(loginIdCookieKey, value);
- // 设置cookie的域,如果不设置该属性将不能够写入cookie
- if (!StringUtils.isBlank(domain)) {
- cookie.setDomain(domain);
- }
- // 设置cookie的路径,这个路径即改工程下都可以访问该cookie 如果不设置路径,那么只有设置该cookie的路径及其子路径可以访问
- if (!StringUtils.isBlank(path)) {
- cookie.setPath(path);
- }
- // 设置cookie的过期时间(单位秒)
- if (expiry > 0) {
- cookie.setMaxAge(expiry);
- }
- response.addCookie(cookie);
- }
- public void setLoginIDCookie1(HttpServletResponse response, String value) {
- Cookie cookie = new Cookie(loginIdCookieKey, value);
- // 设置cookie的域,如果不设置该属性将不能够写入cookie
- if (!StringUtils.isBlank(domain)) {
- cookie.setDomain(domain);
- }
- // 设置cookie的路径,这个路径即改工程下都可以访问该cookie 如果不设置路径,那么只有设置该cookie的路径及其子路径可以访问
- if (!StringUtils.isBlank(path)) {
- cookie.setPath(path);
- }
- // 设置cookie的过期时间(单位秒)
- if (expiry > 0) {
- cookie.setMaxAge(expiry);
- }
- response.addCookie(cookie);
- }

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

关于设置了setMaxAge(0)而浏览器未成功删除Cookie的注意事项的更多相关文章
- 浏览器未安装flash插件,js判断直接去官网安装
近期做了个活动页,里面根据需求插入了阿里云的视频,常见的浏览器都支持包括低版本的. 由于浏览器的更新换代很多版本放弃了flash的插件安装,火狐就是其中之一. 未安装flash的浏览器如果打开这个链接 ...
- 记录修改安卓5.0系统浏览器UI遇到的部分问题
碎碎念 今年七月份本科毕业后入职一家会议平板公司,经过一个一个多月的咸鱼培训轮岗生活,接手了几个小任务,本次记录一下其中一个任务:修改安卓5.0系统浏览器UI.刚接到任务的时候,本以为是很简单的一个任 ...
- 给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 ...
- jquery 设置checked="checked"无效,radio未选中。。
jquery 设置checked="checked"无效,radio未选中.. 最好还是使用.prop(),在jQuery1.6版本之前.attr存在一些bug.在1.6之后它会自 ...
- js设置cookie过期及清除浏览器对应名称的cookie
js设置cookie过期也就相当于清除浏览器对应名称的cookie的例子. 代码: function ClearCookie() { var expires = new Date(); expir ...
- ListView列宽自适应,设置ListView.Column[0].Width := -1;
使用TListView列表显示内容,如果列内容过长,就会显示成‘XXX…’形式,此时如果双击列标题,列宽将变为自适应.用代码设置如下: 1.设置ListView.Column[0].Width := ...
- 快速解决设置Android 23.0以上版本对SD卡的读写权限无效的问题
快速解决设置Android 23.0以上版本对SD卡的读写权限无效的问题 转 https://www.jb51.net/article/144939.htm 今天小编就为大家分享一篇快速解决设置And ...
- Retrofit2.0 ,OkHttp3完美同步持久Cookie实现免登录(二)
原文出自csdn: http://blog.csdn.net/sk719887916/article/details/51700659: 通过对Retrofit2.0的<Retrofit 2.0 ...
- PHP中设置、使用、删除Cookie方法
1.设置Cookie PHP用SetCookie函数来设置Cookie.必须注意的一点是:Cookie是HTTP协议头的一部分,用于浏览器和服务器之间传递信息,所以必须在任何属于HTML文件本身的内容 ...
随机推荐
- Eclipse中设置JDK、${user}变量
为eclipse设置jdk方法: 两个方法: 1.设置PATH路径-eclipse自动会查找! 2.在快捷方式中加上参数:-VM java虚拟机路径 Eclipse中设置${user}变量 在Ecli ...
- IT运维的定义
IT运维是IT管理的核心和重点部分,也是内容最多.最繁杂的部分,该阶段主要用于IT部门内部日常运营管理,涉及的对象分成两大部分,即IT业务系统和运维人员,该阶段的管理内容又可细分为七个子系统: ...
- 如何卸载windows的服务?卸载服务?
前面小编给大家介绍过如何禁用一些不需要的服务: 但是哪些多余的服务其实完成时可以直接卸载掉的: 所以今天小编将指导大家如何卸载一些不需要的服务: 切记请一定要确认卸载的是不需要的服务哦: 工具/原料 ...
- 微信小程序中this关键字使用技巧
转自:https://blog.csdn.net/qq_33956478/article/details/81348453 微信小程序中,在wx.request({});方法调用成功或者失败之后,有时 ...
- httpd 系统错误 无法启动此程序,因为计算机中丢失VCRUNTIME140.dll
说来话长的搭了一个discuz论坛,服务器是apache,我本地的是直接从官网下的(值得吐槽的是官网居然拿不提供编译版本么要从第三方网站获取,不知道为何....),对应apache之前是搭bug管理系 ...
- DirectShow的RTP发包(H264)Filter <转>
转帖地址:http://blog.csdn.net/fan2273/article/details/77653700 DirectShow的RTP发包(H264)Filter 基于DirectShow ...
- Angularjs Ng_repeat中实现复选框选中并显示不同的样式
最近做了一个选择标签的功能,把一些标签展示给用户,用户选择自己喜欢的标签,就类似我们在购物网站看到的那种过滤标签似的: 简单的效果如图所示: 首先看一下html代码: 1 <!DOCTYPE h ...
- axis客户端循环访问webservice的时候只发送了几条数据就断开了的问题
原因 axis客户端访问webservice默认是使用http1.0版本的,这个版本的http不能保持长连接,应该换成http1.1版本 具体修改步骤: <?xml version=" ...
- nginx 真实ip
server { listen 80; server_name localhost; location /{ root html; index index.html index.h ...
- swarmkit
SwarmKit是用于在任何规模上编排分布式系统的工具包. 它包括节点发现的原语,基于raft的共识,任务调度等. 其主要优点是: 分布式:SwarmKit使用raft共识算法来协调,不依赖单一故障点 ...