cookie删除、覆盖不成功

在做登录验证的时候需要用到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就可以啦!)
希望可帮到大家!
  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值