cookie、localStorage和sessionStorage三者区别

本文详细介绍了如何在JavaScript中操作cookie,以及localStorage和sessionStorage的使用方法、生命周期、数据大小和应用场景。对比了三种数据存储方式的优缺点,适合开发者理解并选择合适的存储策略。

cookie

保存cookie值

var dataCookie='110';
document.cookie = 'token' + "=" +dataCookie; 

获取指定名称的cookie值

function getCookie(name) { //获取指定名称的cookie值
// (^| )name=([^;]*)(;|$),match[0]为与整个正则表达式匹配的字符串,match[i]为正则表达式捕获数组相匹配的数组;

  var arr = document.cookie.match(new RegExp("(^| )"+name+"=([^;]*)(;|$)"));

  if(arr != null) {
    console.log(arr);
    return unescape(arr[2]);
  }
  return null;
}

var cookieData=getCookie('token'); //cookie赋值给变量。

ocalStorage和sessionStorage

localStorage和sessionStorage所使用的方法是一样的

var name='sessionData';
var num=120;

sessionStorage.setItem(name,num);//存储数据
sessionStorage.setItem('value2',119);

let dataAll=sessionStorage.valueOf();//获取全部数据
console.log(dataAll,'获取全部数据');

var dataSession=sessionStorage.getItem(name);//获取指定键名数据
var dataSession2=sessionStorage.sessionData;//sessionStorage是js对象,也可以使用key的方式来获取值
console.log(dataSession,dataSession2,'获取指定键名数据');

sessionStorage.removeItem(name); //删除指定键名数据
console.log(dataAll,'获取全部数据1');

sessionStorage.clear();//清空缓存数据:localStorage.clear();
console.log(dataAll,'获取全部数据2');  

使用方式基本就是上面这些

三者的异同

生命周期

cookie:可设置失效时间,没有设置的话,默认是关闭浏览器后失效

localStorage:除非被手动清除,否则将会永久保存。

sessionStorage: 仅在当前网页会话下有效,关闭页面或浏览器后就会被清除。

存放数据大小

cookie:4KB左右

localStorage和sessionStorage:可以保存5MB的信息。

http请求

cookie:每次都会携带在HTTP头中,如果使用cookie保存过多数据会带来性能问题

localStorage和sessionStorage:仅在客户端(即浏览器)中保存,不参与和服务器的通信

易用性

cookie:需要程序员自己封装,源生的Cookie接口不友好

localStorage和sessionStorage:源生接口可以接受,亦可再次封装来对Object和Array有更好的支持

应用场景

从安全性来说,因为每次http请求都会携带cookie信息,这样无形中浪费了带宽,所以cookie应该尽可能少的使用,另外cookie还需要指定作用域,不可以跨域调用,限制比较多。但是用来识别用户登录来说,cookie还是比storage更好用的。其他情况下,可以使用storage,就用storage。

storage在存储数据的大小上面秒杀了cookie,现在基本上很少使用cookie了

localStorage和sessionStorage唯一的差别一个是永久保存在浏览器里面,一个是关闭网页就清除了信息。localStorage可以用来跨页面传递参数,sessionStorage用来保存一些临时的数据,防止用户刷新页面之后丢失了一些参数。

注意点

  1. 如果一个浏览器同时打开两个tab,localstorage和cookie是共享的,sessionstorage是不共享的,这个在处理同一个浏览器登录多个用户的时候会用到
  2. localstorage,sessionstorage在浏览器无痕模式下会存在丢失问题,要做可用性检测(在无痕模式)
    a. localstorage对象仍然存在
    b. 但是setitem会报异常:QuotaExceededError
    c. getItem和removeItem直接忽略
function isLocalStorageSupported() {
    var testKey = 'test',
        storage = window.sessionStorage;
    try {
        storage.setItem(testKey, 'testValue');
        storage.removeItem(testKey);
        return true;
    } catch (error) {
        return false;
    }
}

<think> 首先,用户的问题是关于localStoragesessionStorageCookie之间的区别。我需要根据系统级指令用户可见层的要求来构建回答。 系统级指令关键点: - 所有行内数学表达式使用$...$格式,但在这个上下文中,可能没有数学表达式,所以可以忽略。 - 独立公式使用$$...$$格式,但这里可能不适用。 - LaTeX语法正确:确保任何公式正确,但问题可能不涉及数学。 - 使用中文回答:整个回答必须用中文。 - 生成相关问题:在回答末尾添加相关问题。 - 引用段落末尾添加引用标识:从引用中提取信息时,在句子末尾添加[^1]等。 - 回答结构清晰:帮助用户逐步解决问题,确保真实可靠。 用户可见层要求: - 回答结构清晰,帮助用户逐步解决问题。 - 保证回答真实可靠。 引用内容总结: - 引用[1]:区别包括来源、生命周期、存储大小、数据共享、自动携带应用场景。 - 引用[2]:强调传递性、有效期、存储大小、作用域API使用。 - 引用[3]:简单提到操作API的差异。 用户的问题:想了解localStoragesessionStorageCookie区别。 构建回答结构: 1. **引言**:简要介绍三者是什么,为什么需要比较。 2. **主要区别**:逐步列出关键区别点,参考引用。 3. **总结**:清晰对比表或总结。 4. **相关问题**:生成相关问题。 关键区别点(基于引用): 1. **来源**:Cookie由服务器端写入;localStoragesessionStorage前端写入。 2. **生命周期**: - Cookie:由服务器设置过期时间。 - localStorage:永久存储,除非手动清除。 - sessionStorage:页面关闭时清除。 3. **存储大小**: - Cookie:约4KB。 - localStoragesessionStorage:约5MB或更大。 4. **数据共享**: - CookielocalStorage:在同源窗口中共享。 - sessionStorage:仅在同一页面(标签页)中共享。 5. **HTTP请求**:Cookie会自动在请求中携带;localStoragesessionStorage不会。 6. **应用场景**: - Cookie:用于身份验证(如SessionID或token)。 - localStorage:存储不易变动的数据。 - sessionStorage:临时数据,如页面刷新检测。 7. **API使用**:Cookie操作复杂;localStoragesessionStorage有简单API(setItem, getItem等)。 8. **其他**:如路径概念(Cookie),事件通知(WebStorage)。 确保引用:当使用引用信息时,在句子末尾添加[^1], [^2], [^3]。 回答步骤: 1. 介绍三者。 2. 分点列出区别。 3. 添加总结表。 4. 生成相关问题。 最终输出格式: - 用中文。 - 清晰段落。 - 末尾添加相关问题。 相关问题生成: - 基于主题,如:如何选择使用哪个?具体API示例?安全性考虑?等。 </think>### localStoragesessionStorageCookie区别 localStoragesessionStorageCookie是Web开发中常用的客户端存储技术,主要用于在浏览器端保存数据。它们的核心区别体现在数据来源、生命周期、存储限制、数据共享机制应用场景等方面。下面我将逐步对比分析这些关键差异,帮助您清晰理解。 #### 1. **数据来源** - **Cookie**:由服务器端写入(例如,服务器通过HTTP响应头设置),前端可通过JavaScript修改[^1]。 - **localStoragesessionStorage**:完全由前端写入(JavaScript操作),服务器无法直接干预[^1][^2]。 #### 2. **生命周期** - **Cookie**:生命周期由服务器在写入时设置(如过期时间),到期后自动失效;用户也可手动清除[^1][^2]。 - **localStorage**:永久存储,除非用户手动清除浏览器数据或通过代码删除[^1][^2]。 - **sessionStorage**:仅在当前浏览器标签页或窗口打开期间有效,关闭标签页或窗口后数据自动清除[^1][^2]。 #### 3. **存储大小限制** - **Cookie**:容量较小,约4KB,超出可能导致数据截断[^1][^2]。 - **localStoragesessionStorage**:容量较大,通常支持5MB或更高(取决于浏览器),适合存储更多数据[^1][^2]。 #### 4. **数据共享与作用域** - **Cookie**:在同源(相同协议、域名、端口)的所有窗口标签页中共享,且可设置路径限制(如仅限特定子目录)[^1][^2]。 - **localStorage**:在同源的所有窗口标签页中共享[^2]。 - **sessionStorage**:仅在**同一标签页**内共享,不同标签页或窗口即使同源也无法访问彼此的数据[^1][^2]。 #### 5. **HTTP请求行为** - **Cookie**:浏览器在每次发起HTTP请求时自动携带Cookie数据(通过请求头),可能增加网络负担[^1][^2]。 - **localStoragesessionStorage**:数据仅在本地存储,不会随HTTP请求自动发送到服务器[^1][^2]。 #### 6. **API易用性** - **Cookie**:操作复杂,需手动解析字符串(如`document.cookie`),缺乏标准API[^3]。 - **localStoragesessionStorage**:提供简单API: - 设置数据:`localStorage.setItem('key', 'value')` 或 `sessionStorage.setItem('key', 'value')` - 读取数据:`localStorage.getItem('key')` 或 `sessionStorage.getItem('key')` - 删除数据:`localStorage.removeItem('key')` 或 `sessionStorage.removeItem('key')` - 清空所有:`localStorage.clear()` 或 `sessionStorage.clear()`[^3]。 #### 7. **应用场景** - **Cookie**:主要用于身份验证(如存储SessionID或token)、跟踪用户会话(例如登录状态)[^1]。 - **localStorage**:适合存储长期不变的数据(如用户偏好设置、缓存静态资源),减轻服务器压力[^1]。 - **sessionStorage**:用于临时数据(如页面刷新时恢复表单内容、音乐播放进度条),或检测用户是否通过刷新进入页面[^1]。 #### 总结对比表 | 特性 | Cookie | localStorage | sessionStorage | |----------------------|----------------------------|----------------------------|----------------------------| | **来源** | 服务器端写入 | 前端写入 | 前端写入 | | **生命周期** | 服务器设置过期时间 | 永久(手动清除) | 标签页关闭时清除 | | **存储大小** | ~4KB | ~5MB 或更大 | ~5MB 或更大 | | **数据共享** | 同源窗口共享 | 同源窗口共享 | 仅同一标签页共享 | | **HTTP请求携带** | 自动携带 | 不携带 | 不携带 | | **API易用性** | 复杂(字符串操作) | 简单(标准方法) | 简单(标准方法) | | **典型应用场景** | 登录认证、会话管理 | 长期数据存储 | 临时数据、页面状态恢复 | #### 安全性补充 - 三者都受同源策略限制,但Cookie可能面临CSRF(跨站请求伪造)风险,建议配合HttpOnlySecure标志使用[^2]。 - localStoragesessionStorage不支持事件通知机制(如数据更新监听)[^2]。 如果您需要具体代码示例或进一步解释,请随时告知!
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值