0基础学前端系列 -- 前端的存储方式

前端存储方式全解析:选择最适合你的解决方案

在现代Web开发中,存储用户数据和状态信息是至关重要的。随着应用程序的复杂性增加,开发者需要选择合适的存储机制来管理用户信息。本文将深入探讨前端的存储方式,包括 SessionCookielocalStoragesessionStorageIndexedDB,帮助你理解它们的特点、用途及最佳应用场景。

1. Session(会话)

Session 是一种在用户与服务器之间保持状态的机制。它允许服务器在多个请求之间存储用户的数据,以便在用户的会话期间跟踪其状态。Session 通常用于存储用户的登录状态、购物车信息等。

特点

  • 服务器端存储:Session 数据存储在服务器上,而不是客户端。每个用户的会话数据会与一个唯一的会话ID关联。
  • 会话ID:当用户访问网站时,服务器会生成一个唯一的会话ID,并将其发送到客户端。客户端通常会将该ID存储在 cookie 中,以便在后续请求中发送回服务器。
  • 过期时间:Session 通常有一个过期时间,若在一定时间内没有活动,服务器会自动清除该会话数据。
  • 安全性:由于会话数据存储在服务器端,相对来说比存储在客户端的 cookie 更安全。

示例

假设用户登录到一个电商网站,服务器为该用户生成一个 Session ID,并将其存储在服务器上。每次用户进行购物或浏览时,都会通过 Session ID 来确认用户身份,确保用户的购物车信息不会丢失。

2. Cookie

Cookie 是一种在客户端存储小型数据的机制,通常用于保存用户的状态信息。

特点

  • 设置过期时间:可以设置过期时间,过期后 cookie 会被自动删除。
  • 指定主机:可以指定哪些主机可以访问该 cookie。
  • 大小限制:每个 cookie 的大小限制通常为 4KB。
  • 请求时携带:在每个 HTTP 请求中,相关的 cookie 会自动包含在请求头中发送给服务器。
  • 后端生成:通常由服务器生成并发送到客户端。

示例

当用户登录到网站时,服务器可以创建一个 cookie 来存储用户的登录状态。每次用户访问页面时,浏览器会自动将该 cookie 发送给服务器,从而保持用户登录状态。

// 设置一个 cookie
document.cookie = "username=Alice; expires=Fri, 31 Dec 2024 23:59:59 GMT; path=/";

3. localStorage

localStorage 是一种 Web 存储机制,允许在客户端存储数据。

特点

  • 没有过期时间:存储的数据不会过期,除非手动删除。
  • 大小限制:每个域名下的存储量通常为 5MB。
  • 只能存储字符串:存储的数据必须是字符串类型,如果需要存储对象,需要使用 JSON 序列化。
  • 同源策略:localStorage 遵循同源策略,即同一个源(协议、域名和端口)下的数据可以互相访问。

示例

你可以使用 localStorage 存储用户的偏好设置,比如主题颜色:

// 存储用户的主题设置
localStorage.setItem('theme', 'dark');

// 获取用户的主题设置
const theme = localStorage.getItem('theme');
console.log(theme); // 输出 "dark"

4. sessionStorage

sessionStorage 是另一种 Web 存储机制,与 localStorage 类似,但有一些重要的区别。

特点

  • 会话级别的存储:sessionStorage 的数据仅在页面会话期间有效,关闭浏览器或标签页后数据会被清除。
  • 大小限制:每个域名下的存储量通常为 5MB。
  • 只能存储字符串:同样,存储的数据必须是字符串。
  • 同源策略:遵循同源策略,数据只能在同一源下访问。

示例

当用户在一个表单中输入信息时,可以使用 sessionStorage 暂时保存这些信息,以防止在页面刷新时丢失:

// 存储表单输入
sessionStorage.setItem('formData', JSON.stringify({ name: 'Alice', email: 'alice@example.com' }));

// 获取表单输入
const formData = JSON.parse(sessionStorage.getItem('formData'));
console.log(formData); // 输出 { name: 'Alice', email: 'alice@example.com' }

5. IndexedDB

IndexedDB 是一种低级别的 API,用于在客户端存储大量结构化数据。

特点

  • 异步 API:IndexedDB 的操作是异步的,不会阻塞主线程。
  • 大小限制:理论上没有严格限制,但浏览器会根据设备和存储空间施加限制。
  • 可以存储二进制数据:可以存储复杂的数据类型,包括二进制数据(如图像文件)。
  • 同源策略:遵循同源策略,数据只能在同一源下访问。

示例

IndexedDB 特别适合存储大量数据,比如用户的离线应用数据:

const request = indexedDB.open('myDatabase', 1);

request.onupgradeneeded = function(event) {
    const db = event.target.result;
    const objectStore = db.createObjectStore('users', { keyPath: 'id' });
};

request.onsuccess = function(event) {
    const db = event.target.result;
    const transaction = db.transaction('users', 'readwrite');
    const objectStore = transaction.objectStore('users');

    // 添加用户数据
    objectStore.add({ id: 1, name: 'Alice', email: 'alice@example.com' });
};

总结

在Web开发中,选择合适的存储机制是至关重要的。不同的存储方式各有优缺点,适用于不同的场景:

  • Session:适合存储用户的会话状态,数据存储在服务器端。
  • Cookie:适合存储小型数据,支持过期时间和主机限制。
  • localStorage:适合存储持久的用户偏好设置,数据不会过期。
  • sessionStorage:适合存储会话级别的数据,关闭浏览器后数据会丢失。
  • IndexedDB:适合存储大量结构化数据和二进制数据,支持异步操作。
存储方式存储位置数据大小限制过期时间存储类型同源策略使用场景
Session服务器端取决于服务器配置有过期时间可以存储复杂数据存储用户会话状态,如登录状态、购物车信息
Cookie客户端4KB可设置字符串存储小型数据,如用户登录状态、跟踪信息
localStorage客户端5MB无过期时间字符串存储持久的用户偏好设置,如主题颜色
sessionStorage客户端5MB会话结束时清除字符串存储会话级别数据,如表单输入信息
IndexedDB客户端理论上无限制无过期时间结构化数据、二进制数据存储大量结构化数据,如离线应用数据

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/924354.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

阿里云oss转发上线-实现不出网钓鱼

本地实现阿里云oss转发上线,全部代码在文末,代码存在冗余 实战环境 被钓鱼机器不出网只可访问内部网络包含集团oss 实战思路 若将我们的shellcode文件上传到集团oss上仍无法上线,那么就利用oss做中转使用本地转发进行上线,先发送…

新型大语言模型的预训练与后训练范式,阿里Qwen

前言:大型语言模型(LLMs)的发展历程可以说是非常长,从早期的GPT模型一路走到了今天这些复杂的、公开权重的大型语言模型。最初,LLM的训练过程只关注预训练,但后来逐步扩展到了包括预训练和后训练在内的完整…

C#结构体排序(数组)

结构体排序(数组) 1 示例1.1 以PointF为例展示效果1.2 运行结果展示 2实际运用2.1 创建结构体2.2 调用示例2.3 运行结果展示 1 示例 1.1 以PointF为例展示效果 private void button1_Click(object sender, EventArgs e) {Random random new Random();…

前端高频面试题-并发请求

面试题中,有一道题经常会出现,咱们下面讲一下思路以及写法写一个方法,传入一个请求地址数组,以及一个并发数量,根据并发数量,一起发送请求。如果一个发送完,那么从数组中拿出来一个接着发送&…

RabbitMQ7:消息转换器

欢迎来到“雪碧聊技术”CSDN博客! 在这里,您将踏入一个专注于Java开发技术的知识殿堂。无论您是Java编程的初学者,还是具有一定经验的开发者,相信我的博客都能为您提供宝贵的学习资源和实用技巧。作为您的技术向导,我将…

螺旋矩阵(java)

题目描述 给你一个 m 行 n 列的矩阵 matrix &#xff0c;请按照 顺时针螺旋顺序 &#xff0c;返回矩阵中的所有元素。 代码思路&#xff1a; class Solution {public List<Integer> spiralOrder(int[][] matrix) {List<Integer> list new ArrayList<>(); …

Jenkins的使用

文章目录 一、Jenkins是什么\有什么用\与GitLab的对比二、Jenkins的安装与配置Jenkins的安装方式在Linux上安装Jenkins&#xff1a;在Windows上安装Jenkins&#xff1a;配置Jenkins&#xff1a; &#xff08;可选&#xff09;配置启动用户为root&#xff08;一定要是root吗??…

[在线实验]-ActiveMQ Docker镜像的下载与部署

镜像下载 下载ActiveMQ的Docker镜像文件。通常&#xff0c;这些文件会以.tar格式提供&#xff0c;例如activemq.tar。 docker的activemq镜像资源-CSDN文库 加载镜像 下载完成后&#xff0c;您可以使用以下命令将镜像文件加载到Docker中&#xff1a; docker load --input a…

【AI绘画】Midjourney进阶:色调详解(下)

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: AI绘画 | Midjourney 文章目录 &#x1f4af;前言&#x1f4af;Midjourney中的色彩控制为什么要控制色彩&#xff1f;为什么要在Midjourney中控制色彩&#xff1f; &#x1f4af;色调纯色调灰色调暗色调 &#x1f4af…

YOLO系列论文综述(从YOLOv1到YOLOv11)【第3篇:YOLOv1——YOLO的开山之作】

YOLOv1 1 摘要2 YOLO: You Only Look Once2.1 如何工作2.2 网络架构2.3 训练2.4 优缺点 YOLO系列博文&#xff1a; 【第1篇&#xff1a;概述物体检测算法发展史、YOLO应用领域、评价指标和NMS】【第2篇&#xff1a;YOLO系列论文、代码和主要优缺点汇总】 ——————————…

数字图像处理(9):VGA接口及其时序

&#xff08;1&#xff09;特点&#xff1a;成本低、结构简单、应用灵活 VGA接口需要五个信号&#xff1a;R、G、B、Hsync、Vsync &#xff08;2&#xff09;VGA的工作原理&#xff1a; 设定一个高速时钟信号&#xff08;像素时钟&#xff09;来控制每个像素的传输速率&#…

微信小程序按字母顺序渲染城市 功能实现详细讲解

在微信小程序功能搭建中&#xff0c;按字母渲染城市会用到多个ES6的方法&#xff0c;如reduce&#xff0c;map&#xff0c;Object.entries()&#xff0c;Object.keys() &#xff0c;需要组合熟练掌握&#xff0c;才能优雅的处理数据完成渲染。 目录 一、数据分析 二、数据处理 …

DVWA靶场通过——文件上传漏洞

File Upload漏洞 它允许攻击者通过上传恶意文件来执行任意代码、窃取数据、获取服务器权限&#xff0c;甚至完全控制服务器。为了防止文件上传漏洞&#xff0c;开发者需要对文件上传过程进行严格的验证和处理。 1. 文件上传漏洞概述 文件上传漏洞发生在Web应用程序允许用户通过…

react后台管理系统(一)

&#x1f308;个人主页&#xff1a;前端青山 &#x1f525;系列专栏&#xff1a;React篇 &#x1f516;人终将被年少不可得之物困其一生 依旧青山,本期给大家带来React篇专栏内容:react后台管理系统(一) 前言 本文档详细介绍了如何从零开始搭建一个基于 React 和 Ant Design 的…

Vue.js --- 生命周期

1. 前言 在 Vue.js 中&#xff0c;生命周期是指一个 Vue 实例从创建到销毁的过程。Vue 提供了一系列的生命周期钩子&#xff08;lifecycle hooks&#xff09;&#xff0c;让开发者可以在不同的阶段执行特定的代码。了解这些生命周期钩子是构建 Vue 组件的基础&#xff0c;能够…

使用1panel一键安装Ollama WebUI连接本地Ollama使用开源ai模型

当前我的环境 设备有限只有一张3060 12gb显卡&#xff0c;平时用来轻度学习 主机&#xff1a;windows server Ollama&#xff1a;windows版&#xff08;它也有linux和mac&#xff09; 因虚拟机使用的服务器无显卡&#xff0c;只用来跑面板和WebUi 虚拟机&#xff1a;ubuntu se…

任意文件读取漏洞(CVE-2024-7928)修复

验证CVE-2024-7928问题是否存在可以使用如下方法&#xff1a; https://域名/index/ajax/lang?lang..//..//目录名/文件名&#xff08;不带后缀&#xff09; 目录名是该项目的一个目录&#xff0c;这里目录位置为nginx设置站点目录为基准&#xff0c;网上两层目录。 文件名…

房屋出租出售预约系统支持微信小程序+H5+APP

核心功能有&#xff1a;新盘销售、房屋租赁、地图找房、小区找房&#xff0c;地铁找房等方式。 地图找房&#xff1a;通过地图标注查看附近房源&#xff0c;方便用户根据地理位置查找合适的房产。二手房资讯&#xff1a;提供租房及二手房市场的相关资讯&#xff0c;帮助用户了…

设计模式:11、迭代器模式(游标)

目录 0、定义 1、迭代器模式的四种角色 2、迭代器模式的UML类图 3、示例代码 4、迭代器的next()方法与集合的get(int index)方法的效率对比&#xff08;LinkedList为例&#xff09; 0、定义 提供一种方法顺序访问一个聚合对象中的各个元素&#xff0c;而又不需要暴露该对象…

抓SystemTrace的简易方法

前言&#xff1a; Systrace是分析Android性能问题的神器。一般抓trace命令是需要在AndroidSDK下的\platform-tools\systrace执行\systrace.py&#xff0c;很奇怪我的AndroidSDK并没有systrace文件夹&#xff0c;于是CSDN单独下载了trace文件 但是我一运行.\systrace.py -b 102…