当前位置: 首页 > news >正文

浏览器存储技术:localStorage、sessionStorage和cookie的区别

随着互联网技术的不断发展,人们越来越依赖浏览器进行网页浏览和数据处理。浏览器存储技术是Web开发中非常重要的一部分,它可以帮助我们在浏览器端存储数据,而无需将数据传输到服务器。本文将介绍三种常见的浏览器存储技术:localStorage、sessionStorage和cookie,探讨它们的区别以及各自适用的场景。

一、localStorage

localStorage 是 HTML5 标准中新增的一种客户端存储数据的方式。它提供了一个存储在客户端的键值对(key-value)对象,这些数据在关闭浏览器后仍然保留。localStorage 中的数据是按照域名和协议分离的,不同的域名和协议不能共享数据。

使用localStorage存储数据非常简单。我们可以使用setItem方法设置一个键值对,使用getItem方法获取一个键对应的值,使用removeItem方法删除一个键值对,使用clear方法清空所有的键值对。下面是一个使用localStorage的示例:

localStorage.setItem('name', 'Tom');
var name = localStorage.getItem('name');
localStorage.removeItem('name');
localStorage.clear();

localStorage 适用于需要长期存储的数据,例如用户的偏好设置、表单数据等。由于 localStorage 中的数据在关闭浏览器后仍然保留,因此它可以在多个页面之间共享数据。同时,由于 localStorage 中的数据只能通过 JavaScript 访问,因此它比 cookie 更加安全。

二、sessionStorage

sessionStorage 和 localStorage 类似,都是客户端存储数据的方式。它也提供了一个键值对对象,但是与 localStorage 不同的是,sessionStorage 中的数据在关闭浏览器后就会被清除。同时,sessionStorage 中的数据也是按照域名和协议分离的,不同的域名和协议不能共享数据。

使用 sessionStorage 存储数据也非常简单。我们可以使用setItem方法设置一个键值对,使用getItem方法获取一个键对应的值,使用removeItem方法删除一个键值对,使用clear方法清空所有的键值对。下面是一个使用 sessionStorage 的示例:

sessionStorage.setItem('name', 'Tom');
var name = sessionStorage.getItem('name');
sessionStorage.removeItem('name');
sessionStorage.clear();

sessionStorage 适用于临时存储数据,例如用户在填写表单时,需要在多个页面之间保存一些数据,但是不需要在关闭浏览器后保留数据。由于 sessionStorage 中的数据在关闭浏览器后就会被清除,因此它不适合长期存储数据。同时,由于 sessionStorage 中的数据只能通过 JavaScript 访问,因此它比 cookie 更加安全。

三、cookie

cookie 是一种在客户端存储数据的方式,它最早由 Netscape 公司在1994年引入,是目前使用最广泛的浏览器存储技术之一。与 localStorage 和 sessionStorage 不同的是,cookie 中的数据会随着 HTTP 请求一起发送到服务器端,因此它可以在不同的域名和协议之间共享数据。

使用 cookie 存储数据也非常简单。我们可以使用 document.cookie 属性设置一个键值对,使用正则表达式或第三方库来获取一个键对应的值,使用 expire 过期时间和 path 属性来控制 cookie 的有效期和访问路径。下面是一个使用 cookie 的示例:

document.cookie = 'name=Tom; expires=Wed, 09 May 2023 00:00:00 UTC; path=/';
var name = document.cookie.replace(/(?:(?:^|.*;\s*)name\s*\=\s*([^;]*).*$)|^.*$/, "$1");

cookie 适用于需要在不同的域名和协议之间共享数据的场景,例如用户的登录信息、购物车信息等。由于 cookie 中的数据会随着 HTTP 请求一起发送到服务器端,因此它的安全性比 localStorage 和 sessionStorage 低一些。另外,由于 cookie 中的数据可以被其他网站访问和篡改,因此开发人员需要注意在设置 cookie 的时候设置合适的过期时间和访问路径,以保护用户的隐私和安全。

四、localStorage、sessionStorage和cookie的区别

通过上面的介绍,我们可以看出 localStorage、sessionStorage 和 cookie 之间存在一些区别:

  1. 存储方式不同:localStorage 和 sessionStorage 都是将数据存储在客户端的键值对对象中,而 cookie 是将数据存储在客户端的文本文件中。

  2. 数据保留时间不同:localStorage 中的数据在关闭浏览器后仍然保留,而 sessionStorage 中的数据在关闭浏览器后就会被清除,cookie 中的数据可以设置过期时间,也可以在浏览器关闭后保留。

  3. 数据访问范围不同:localStorage 和 sessionStorage 中的数据按照域名和协议分离,不同的域名和协议不能共享数据,而 cookie 中的数据可以在不同的域名和协议之间共享数据。

  4. 数据大小限制不同:localStorage 和 sessionStorage 的数据大小一般为 5MB 左右,而 cookie 的数据大小限制为 4KB 左右。

  5. 数据访问方式不同:localStorage 和 sessionStorage 中的数据只能通过 JavaScript 访问,而 cookie 中的数据可以通过 JavaScript 和 HTTP 请求访问。

  6. 数据安全性不同:localStorage 和 sessionStorage 中的数据只能在客户端被访问,因此比 cookie 更加安全,而 cookie 中的数据可以被其他网站访问和篡改,因此需要注意安全性问题。

六、如何选择合适的浏览器存储技术?

选择合适的浏览器存储技术需要考虑多个因素,包括数据大小、数据访问方式、数据保留时间、数据访问范围和数据安全性等。

如果需要存储较大的数据,建议使用 localStorage 或 sessionStorage,因为它们的数据大小限制比 cookie 大得多。如果需要在不同的域名和协议之间共享数据,可以使用 cookie,但需要注意安全性问题。如果需要在会话期间存储数据,建议使用 sessionStorage,因为它的数据会在浏览器关闭后被清除,不会占用过多的存储空间。

在使用浏览器存储技术的过程中,还需要注意一些细节问题。例如,由于 localStorage 和 sessionStorage 中的数据只能通过 JavaScript 访问,因此需要注意跨域访问的问题;另外,由于 cookie 中的数据可以被其他网站访问和篡改,因此需要注意设置合适的过期时间和访问路径,以保护用户的隐私和安全。

七、总结

浏览器存储技术是 Web 开发中非常重要的一部分,它可以帮助开发人员在客户端存储和获取数据,提高应用程序的性能和用户体验。在使用 localStorage、sessionStorage 和 cookie 的过程中,需要注意数据大小、数据保留时间、数据访问范围和数据安全性等问题,选择合适的存储方式,以满足不同的业务需求。同时,还需要注意浏览器存储技术的兼容性和安全性问题,保护用户的隐私和安全。

在未来的 Web 开发中,浏览器存储技术还将继续发展和完善,提供更加强大和灵活的功能和接口,为开发人员带来更好的开发体验和更高的效率。

相关文章:

浏览器存储技术:localStorage、sessionStorage和cookie的区别

随着互联网技术的不断发展,人们越来越依赖浏览器进行网页浏览和数据处理。浏览器存储技术是Web开发中非常重要的一部分,它可以帮助我们在浏览器端存储数据,而无需将数据传输到服务器。本文将介绍三种常见的浏览器存储技术:localSt…...

MySQL中的内连接和外连接

一、MySQL内连接(INNER JOIN) 内连接,又称为等值连接,是最常见的连接类型。它根据两个(或多个)表中具有相同列值的行来创建一个新的结果表。在内连接中,只有通过连接条件匹配的行才会被包含在结…...

node学习手册

Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行时,使 JavaScript 可以脱离浏览器环境运行在服务端。它提供了一组 API,可以让开发者轻松地进行服务器端编程。 以下是 Node.js 的学习手册: 安装 Node.js 首先,需要在官网…...

Java中的JSP是什么?如何实现JSP

JavaServer Pages(JSP)是一种Java技术,可以用于开发动态Web应用程序。它允许开发人员将Java代码嵌入到HTML页面中,以便生成动态内容。本文将介绍JSP的工作原理,以及如何在Java中实现JSP。 JSP的工作原理 JSP的工作原…...

c++之函数对象和谓词

目录 函数对象: 谓词: 一元谓词函数举例如下 二元谓词举例如下 函数对象和函数的区别 一元谓词的案例 二元函数对象案例 二元谓词案例 函数对象: 重载函数调用操作符的类,其对象常称为函数对象(function obj…...

《Andorid开源》greenDao 数据库orm框架

一 前言:以前没用框架写Andorid的Sqlite的时候就是用SQLiteDatabase ,SQLiteOpenHelper ,SQL语句等一些东西,特别在写SQL语句来进行 数据库操作的时候是一件很繁琐的事情,有时候没有错误提示的,很难找到错误的地方&a…...

Android类似微信聊天页面教程(Kotlin)五——选择发送图片

前提条件 安装并配置好Android Studio Android Studio Electric Eel | 2022.1.1 Patch 2 Build #AI-221.6008.13.2211.9619390, built on February 17, 2023 Runtime version: 11.0.150-b2043.56-9505619 amd64 VM: OpenJDK 64-Bit Server VM by JetBrains s.r.o. Windows 11 …...

MongoDB:Win/Linux环境安装及一键部署脚本

1. Win安装 1.1 下载 MongoDB 安装程序 访问 MongoDB 官网,进入下载页面:Download MongoDB Community Server | MongoDB 选择 Windows 平台并下载最新版的 MongoDB 安装程序。 1.2 安装 MongoDB 双击安装程序,按照提示完成 MongoDB 的安装…...

KingbaseES V8R3 集群运维系列 -- failover切换后集群自动恢复

​ 案例说明: KingbaseES V8R3集群默认在触发failover切换后,为保证数据安全,原主库需要通过人工介入后,恢复为新的备库加入到集群。在无人值守的现场环境,需要在触发failover切换后,主库可以自动恢复为新备…...

【Selenium中】——全栈开发——如桃花来

目录索引 查找元素:查找方法:单个元素查找:多个元素查找:*代码演示:* 元素交互操作:清空文字: 推荐的变量名定义名称:执行JavaScript :滚动页面方法:*滚动到底…...

Sarsa增强版之Sarsa-λ依然走迷宫

Sarsa-λ(Sarsa Lambda)是Sarsa算法的一种变体,其中“λ”表示一个介于0和1之间的参数,用于平衡当前状态和之前所有状态的重要性。 Sarsa算法是一种基于Q-learning算法的增量式学习方法,通过在实际环境中不断探索和学…...

生成 Cypher 能力:MOSS VS ChatGLM

生成 Cypher 能力:MOSS VS ChatGLM 生成 Cypher 能力:MOSS VS ChatGLM一、 测试结果二、 测试代码(包含Prompt) Here’s the table of contents: 生成 Cypher 能力:MOSS VS ChatGLM MOSS介绍:MOSS 是复旦大…...

数据库的键和存储

主键:数据库表中对存储数据对象给予以唯一和完整表示的数据列或属性的组合。一个数据列只能有一个主键,且主键的取值不能缺失,即不能为空。 外键:在一个表中存在另一个表得主键称此为表的外键。 为什么用自增列作为主键? 如果我们定义了主…...

基于AT89C51单片机的并入串出乘法口诀的设计与仿真

点击链接获取Keil源码与Project Backups仿真图: https://download.csdn.net/download/qq_64505944/87779146?spm1001.2014.3001.5503 源码获取 并入串出乘法口诀的设计与仿真系统设计 目录 第一章 概述 3 1.1课题研究及意义 3 1.2课题设计内容 4 第二章系统设计…...

人生在世皆有过错,来一起看看Java中的异常吧!!!

Java中的异常问题详解 一、异常的概念与分类 1.异常概念 概念:Java异常是一个描述在代码段中发生异常的对象,当发生异常情况时,一个代表该异常的对象被创建并且在导致该异常的方法中被抛出,而该方法可以选择自己处理异常或者传…...

linux 测试连接网络和端口 telnet

一、安装telnet 1、检测telnet-server的rpm包是否安装 [rootlocalhost ~]# rpm -qa telnet-server 若无输入内容,则表示没有安装。出于安全考虑telnet-server.rpm是默认没有安装的,而telnet的客户端是标配。即下面的软件是默认安装的。 2、若未安装&…...

一文快速入门体验 Hibernate

前言 Hibernate 是一个优秀的持久层的框架,当然,虽然现在说用得比较多的是 MyBaits,但是我工作中也不得不接触 Hibernate,特别是一些老项目需要你维护的时候。所以,在此写下这篇文章,方便自己回顾&#xf…...

【RabbitMQ】SpringAMQP

RabbitMQ 1.初识MQ 1.1.同步和异步通讯 微服务间通讯有同步和异步两种方式: 同步通讯:就像打电话,需要实时响应。 异步通讯:就像发邮件,不需要马上回复。 两种方式各有优劣,打电话可以立即得到响应&am…...

错题汇总08

1.如果友元函数重载一个运算符时,其参数表中没有任何参数则说明该运算符是 A 一元运算符 B 二元运算符 C 选项A)和选项B)都可能 D 重载错误 运算符重载 1.重载成类的成员函数------>形参数目看起来比该运算符需要的参数个数少1&#x…...

使用urllib库简单入门

使用urllib库简单入门 Python中的urllib库是一个非常强大的工具,它提供了一些模块,如urllib.request、urllib.parse、urllib.error、urllib.robotparser等,可以用来处理URLs和网页数据的获取、发送和处理。 在本文中,我们将介绍…...

MMaDA: Multimodal Large Diffusion Language Models

CODE : https://github.com/Gen-Verse/MMaDA Abstract 我们介绍了一种新型的多模态扩散基础模型MMaDA,它被设计用于在文本推理、多模态理解和文本到图像生成等不同领域实现卓越的性能。该方法的特点是三个关键创新:(i) MMaDA采用统一的扩散架构&#xf…...

AspectJ 在 Android 中的完整使用指南

一、环境配置(Gradle 7.0 适配) 1. 项目级 build.gradle // 注意:沪江插件已停更,推荐官方兼容方案 buildscript {dependencies {classpath org.aspectj:aspectjtools:1.9.9.1 // AspectJ 工具} } 2. 模块级 build.gradle plu…...

C# 求圆面积的程序(Program to find area of a circle)

给定半径r,求圆的面积。圆的面积应精确到小数点后5位。 例子: 输入:r 5 输出:78.53982 解释:由于面积 PI * r * r 3.14159265358979323846 * 5 * 5 78.53982,因为我们只保留小数点后 5 位数字。 输…...

面向无人机海岸带生态系统监测的语义分割基准数据集

描述:海岸带生态系统的监测是维护生态平衡和可持续发展的重要任务。语义分割技术在遥感影像中的应用为海岸带生态系统的精准监测提供了有效手段。然而,目前该领域仍面临一个挑战,即缺乏公开的专门面向海岸带生态系统的语义分割基准数据集。受…...

系统掌握PyTorch:图解张量、Autograd、DataLoader、nn.Module与实战模型

本文较长,建议点赞收藏,以免遗失。更多AI大模型应用开发学习视频及资料,尽在聚客AI学院。 本文通过代码驱动的方式,系统讲解PyTorch核心概念和实战技巧,涵盖张量操作、自动微分、数据加载、模型构建和训练全流程&#…...

【FTP】ftp文件传输会丢包吗?批量几百个文件传输,有一些文件没有传输完整,如何解决?

FTP(File Transfer Protocol)本身是一个基于 TCP 的协议,理论上不会丢包。但 FTP 文件传输过程中仍可能出现文件不完整、丢失或损坏的情况,主要原因包括: ✅ 一、FTP传输可能“丢包”或文件不完整的原因 原因描述网络…...

Android写一个捕获全局异常的工具类

项目开发和实际运行过程中难免会遇到异常发生,系统提供了一个可以捕获全局异常的工具Uncaughtexceptionhandler,它是Thread的子类(就是package java.lang;里线程的Thread)。本文将利用它将设备信息、报错信息以及错误的发生时间都…...

第八部分:阶段项目 6:构建 React 前端应用

现在,是时候将你学到的 React 基础知识付诸实践,构建一个简单的前端应用来模拟与后端 API 的交互了。在这个阶段,你可以先使用模拟数据,或者如果你的后端 API(阶段项目 5)已经搭建好,可以直接连…...

高防服务器价格高原因分析

高防服务器的价格较高,主要是由于其特殊的防御机制、硬件配置、运营维护等多方面的综合成本。以下从技术、资源和服务三个维度详细解析高防服务器昂贵的原因: 一、硬件与技术投入 大带宽需求 DDoS攻击通过占用大量带宽资源瘫痪目标服务器,因此…...

pgsql:还原数据库后出现重复序列导致“more than one owned sequence found“报错问题的解决

问题: pgsql数据库通过备份数据库文件进行还原时,如果表中有自增序列,还原后可能会出现重复的序列,此时若向表中插入新行时会出现“more than one owned sequence found”的报错提示。 点击菜单“其它”-》“序列”,…...