[Web数据控制]浏览器中cookie、localStorage和sessionStorage

前言

最近在跟随公司的前辈大哥们做一个全栈项目,让我负责前端页面数据的存取控制。想要做好网站的数据存取控制,就需要明白好客户端的浏览器各个域的作用机制。

区别

共享性

cookie和localStorage都是跟随同一个网址的存储空间。在同一个网址下,所有的标签页之间共享cookie和localStorage。

而sessionStorage是当前标签页下有效。同一个网站不同的标签页,sessionStorage一般是不共享的。只有同源窗口(协议、域名、端口一致,注意是这里说的是窗口,不是标签页和网址),不同页面可以共享sessionStorage的值。意思就是,如果我新的一页是通过 window.open 方法或者是通过链接打开时,新页面会复制前一个页面的sessionStorage。

保存时长

localStorage:永久有效,除非script代码清除或者删除浏览器缓存

sessionStorage:当前会话内有效,当窗口关闭时(刷新可以视为重启页面,也有关闭页面的行为)清除里面的数据。

cookie:由开发者编辑代码时设置,大多开发框架默认行为是设置成永久有效,同localStorage一样。也可以由开发者设置过期时长。

最后一个重要的差别是,cookie中的内容会跟随在每一个请求头中,而localStorage和sessionStorage不会。

相关推荐
朦胧之17 小时前
AI 编程-老项目改造篇
java·前端·后端
swipe20 小时前
从 0 到 1 实现大文件上传:分片、秒传、断点续传、暂停、重试与服务端合并
前端·javascript·面试
爱勇宝20 小时前
我做了一个只用来搜歌词的小 App
android·前端·后端
甲维斯20 小时前
用AI还原《坦克大战》并3D化升级!
前端·人工智能·游戏开发
IT_陈寒21 小时前
SpringBoot自动配置坑了我一晚上,原来问题出在这
前端·人工智能·后端
kyriewen21 小时前
AI 生成的代码能跑就行?这 5 个坑迟早炸
前端·javascript·ai编程
谷子在生长1 天前
纯血鸿蒙自定义弹窗最佳实践:从「到处复制」到「一行调用」
前端·harmonyos
壹方秘境1 天前
我用Go语言开发了一个跨平台的HTTPS抓包和调试工具
前端·后端·ios
神秘面具男1 天前
HarmonyOS 6.0跨端远程控制
前端·后端
枫树下x1 天前
NestJS基础框架
前端