IE下javascript cookie path设置Bug
16lz
2021-01-22
项目中设置完cookie,在Firefox下顺利测试通过。IE测试出现问题,经定位发现是Javascript设置 Cookie 时的 path 有问题。IE下Cookie设置在 /或者URL所在路径时正常,如果Cookie值作用域在当前URL下,则IE下javascript 无法获取到设置的Cookie值。
看下面演示代码,注意下面的path 区别:
- varcookie_name="name";
- varcookie_value="value";
- expires=newDate();
- expires.setTime(expires.getTime()+86400*1000);
- //有Bugdocument.cookie无法读取到cookie_name值
- document.cookie=cookie_name+"="+encodeURIComponent(cookie_value)
- +";expires="+expires.toGMTString()+";path="
- +window.location.pathname;
- //正常
- document.cookie=cookie_name+"="+encodeURIComponent(cookie_value)
- +";expires="+expires.toGMTString()+";path=/test/";
- //正常
- document.cookie="cookie_name="+encodeURIComponent(cookie_value)
- +";expires="+expires.toGMTString()+";path=/";
得出结果:cookie值只对当前页面有效。现在不知道
替代方案,代码:
- //IECookieBug替代方案
- varcookie_path=window.location.pathname;
- varcookie_name=encodeURIComponent(cookie_path.substring(cookie_path
- .lastIndexOf('/')+1));
- cookie_path=cookie_path.substring(0,cookie_path.lastIndexOf('/')+1);
- varcookie_value="value";
- expires=newDate();
- expires.setTime(expires.getTime()+86400*1000);
- document.cookie=cookie_name+"="+encodeURIComponent(cookie_value)
- +";expires="+expires.toGMTString()+";path="+cookie_path;
替代方案根据每个页面的URL文件名来做Cookie名,有效范围在当前页路经下。
如:url 等于 /test/test.html
则cookie名为test.html,有效路径为/test/
这样也可以做到同一个js部署在每个页面上能读到只对当前URL有效的cookie值。代价是当用户在同一级目录下访问很多页面时会导致cookie值不 断增大。结果是当前路径下的每个http请求都带很长一段的cookie,直接导致服务器接收客户端request的header长度增长,流量增长的同 时服务器负担也变重。而且根据RFC 2109的定义Cookie也有长度和个数限制,IE允许的最大 Cookie 长度是 4096 字节,允许50个Cookie 名-值对。如果要突破50个名-值对的限制,可以在一个名-值使用Cookie字典的方式保存更多的Cookie变量。
参考自:http://conkeyn.iteye.com/blog/423549
更多相关文章
- JS在页面加载时候onload与匿名自调用函数的区别
- “错误:路径必须是字符串”(v5.10.0)
- 如何在HTML页面中维护SWF文件的大小?
- 鼠标按下时是否可以防止鼠标光标离开页面
- 【JavaScript】案例一:使用JS完成注册页面表单校验
- electron 将pc端(vue)页面打包为桌面端应用
- 从打印页面中删除网址并打印文本
- 如何在我的页面上以漂亮的格式显示JSON对象?(复制)
- 如何从单一路径获取上层路径?