概述
在做登录验证的时候需要用到cookie来保存用户名称,来判断用户是否是通过登录页面登录而非输入url进入页面。(也可以用session在服务端进行操作,利用springmvc的intercepter拦截器)。
我选择用cookie,在前端进行登录校验,这样写比较简单。但是在编写过程中,遇到了cookie无法覆盖,无法删除的情况。根据其他博客的写法,cookie是以键值对的方式存储:具体的crud详见:
http://www.runoob.com/js/js-cookies.html
,上面写的很细致。
要想覆盖cookie或者删除cookie,必须要设置cookie的path!例如:
document.cookie="status=success;expires=Thu, 18 Dec 2018 12:00:00 GMT; path=/";
如果不设置,就算是你讲cookie的时间设置为过期的,也不能删除。同样也无法覆盖,例如我在写两个cookie:document.cookie="status=success";document.cookie="status=failse";我们预期的结果是cookie会被覆盖,但结果会是 status=success;status=failse 这样的叠加情况(是个string字符串,中间用;隔开)。
注:亲测是这样,网上有很多博客都写将cookie的时间设为过期即可,例如:
//获取当前时间
var date=new Date();
//将date设置为过去的时间
date.setTime(date.getTime()-10000);
//将userId这个cookie删除
document.cookie="userId=828; expire="+date.toGMTString();
这样并不能删除,切记要设置path,或者设置path和domain(网上有人说要设置这两个,担我只设置了path就可以啦!)
希望可帮到大家!
最后
以上就是老实口红为你收集整理的cookie删除、覆盖不成功的全部内容,希望文章能够帮你解决cookie删除、覆盖不成功所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复