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

前端会话控制技术:cookie/session/token

目录

  • 前端中的 Cookie、Session 和 Token:详解与应用
    • 1. Cookie
      • 1.1 什么是 Cookie?
      • 1.2 Cookie 的工作原理
      • 1.3 Cookie 的特点
      • 1.4 Cookie 的用途
      • 1.5 Cookie 的安全性
    • 2. Session
      • 2.1 什么是 Session?
      • 2.2 Session 的工作原理
      • 2.3 Session 的特点
      • 2.4 Session 的用途
      • 2.5 Session 的安全性
    • 3. Token
      • 3.1 什么是 Token?
      • 3.2 Token 的工作原理
      • 3.3 Token 的特点
      • 3.4 Token 的用途
      • 3.5 Token 的安全性
    • 4. Cookie、Session 和 Token 的对比
    • 5.补充说明
      • 5.1 token的无状态是什么意思
        • 无状态的优势
        • 实际应用示例
    • 6. 如何选择?

前端中的 Cookie、Session 和 Token:详解与应用

在前端开发中,管理用户状态和实现身份验证是至关重要的任务。为了实现这些功能,开发者通常会使用 CookieSessionToken 这三种机制。它们各有特点,适用于不同的场景。本文将深入探讨它们的定义、工作原理、优缺点以及实际应用。


1. Cookie

在这里插入图片描述

1.1 什么是 Cookie?

Cookie 是服务器发送到用户浏览器并保存在本地的一小块数据(通常小于 4KB)。浏览器会在后续请求中自动将 Cookie 发送回服务器。

1.2 Cookie 的工作原理

  1. 服务器通过 HTTP 响应头的 Set-Cookie 字段将 Cookie 发送给浏览器。
  2. 浏览器保存 Cookie,并在后续请求中通过 Cookie 请求头将其发送回服务器。
  3. 服务器根据 Cookie 的内容识别用户或会话状态。

1.3 Cookie 的特点

  • 存储位置: 客户端(浏览器)。
  • 生命周期: 可以设置过期时间(会话 Cookie 或持久 Cookie)。
  • 自动发送: 每次请求都会自动发送到服务器。
  • 大小限制: 单个 Cookie 通常不超过 4KB,每个域名下的 Cookie 数量也有限制。

1.4 Cookie 的用途

  • 会话管理: 如保存登录状态、购物车信息。
  • 个性化设置: 如用户的语言偏好、主题设置。
  • 行为跟踪: 如广告投放、用户行为分析。

1.5 Cookie 的安全性

  • 优点: 简单易用,适合存储少量非敏感数据。
  • 缺点: 容易受到 CSRF(跨站请求伪造)和 XSS(跨站脚本攻击)的威胁。
  • 防护措施:
    • 使用 HttpOnly 属性防止 JavaScript 访问。
    • 使用 Secure 属性确保仅通过 HTTPS 传输。
    • 使用 SameSite 属性防止跨站请求伪造。

2. Session

2.1 什么是 Session?

Session 是服务器端存储的用户会话数据,通常与一个唯一的 Session ID 关联。Session ID 通过 Cookie 或 URL 传递给客户端。

2.2 Session 的工作原理

  1. 用户登录后,服务器创建一个 Session 并生成唯一的 Session ID。
  2. 服务器将 Session ID 通过 Cookie 或 URL 传递给客户端。
  3. 客户端在后续请求中发送 Session ID,服务器根据 ID 查找对应的 Session 数据。

2.3 Session 的特点

  • 存储位置: 服务器端(如内存、数据库)。
  • 生命周期: 会话结束时销毁,或根据设置的时间过期。
  • 依赖 Cookie: 通常通过 Cookie 传递 Session ID。

2.4 Session 的用途

  • 用户状态管理: 如保存登录状态、用户权限。
  • 临时数据存储: 如表单数据、购物车信息。

2.5 Session 的安全性

  • 优点: 敏感数据存储在服务器端,不易被客户端篡改。
  • 缺点: 需要服务器维护会话状态,可能影响扩展性。
  • 防护措施:
    • 使用 HTTPS 加密传输。
    • 定期清理过期 Session。

3. Token

3.1 什么是 Token?

Token 是一种用于身份验证和授权的令牌,通常采用 JSON Web Token (JWT) 格式。Token 包含用户信息、签名和过期时间等数据。

3.2 Token 的工作原理

  1. 用户登录后,服务器生成一个 Token 并返回给客户端。
  2. 客户端将 Token 存储在 LocalStorage、SessionStorage 或 Cookie 中。
  3. 客户端在后续请求中通过 Authorization 请求头发送 Token。
  4. 服务器验证 Token 的合法性并处理请求。

3.3 Token 的特点

  • 存储位置: 客户端(如 LocalStorage、SessionStorage 或 Cookie)。
  • 自包含: 包含用户信息和签名,无需服务器存储。
  • 手动发送: 需要手动附加到请求头。

3.4 Token 的用途

  • 无状态身份验证: 如 RESTful API。
  • 跨域认证: 如单点登录(SSO)。

3.5 Token 的安全性

  • 优点: 无状态,适合分布式系统;支持跨域认证。
  • 缺点: 需要妥善存储,防止 XSS 攻击。
  • 防护措施:
    • 使用 HTTPS 加密传输。
    • 避免将 Token 存储在 LocalStorage 中,防止 XSS 攻击。

4. Cookie、Session 和 Token 的对比

特性CookieSessionToken (JWT)
存储位置客户端(浏览器)服务器端客户端(LocalStorage 等)
数据传输自动通过 Cookie 头发送通过 Session ID手动附加到请求头
安全性较低(易受 CSRF 攻击)较高较高(依赖加密算法)
扩展性较好较差(需服务器存储)较好(无状态)
适用场景会话管理、个性化服务器端状态管理无状态认证、跨域认证

5.补充说明

5.1 token的无状态是什么意思

Token 的无状态(stateless)指的是服务器端不需要存储 token 或与之相关的会话信息。这个特性是 token(尤其是 JWT)的一个重要优势,具体含义如下:

  • 服务器不保存会话数据:传统的 session 认证方式中,服务器需要在内存或数据库中保存每个用户的会话状态。而使用 token 时,服务器不需要保存任何会话状态。
  • 自包含信息:token(如 JWT)本身包含了所有必要的信息,比如用户 ID、权限、过期时间等。这些信息经过加密签名,确保不被篡改。
  • 独立验证:服务器只需验证 token 的签名是否有效,而不需要查询数据库或存储系统来验证用户身份。
无状态的优势
  • 可扩展性:由于不需要在服务器存储会话信息,系统更容易水平扩展。多台服务器可以独立处理请求,不需要共享会话存储。

  • 减轻服务器负担:不需要为每个用户维护状态,降低了服务器的内存占用和数据库查询。

  • 适合微服务架构:不同的微服务可以独立验证 token,不需要共享会话状态。

  • 跨域支持:由于不依赖于 cookie,更容易实现跨域认证。

实际应用示例

假设用户登录后,服务器生成一个包含用户 ID 和权限的 JWT:

// JWT 的结构(简化示例)
{
  "header": { "alg": "HS256", "typ": "JWT" },
  "payload": {
    "userId": "12345",
    "role": "admin",
    "exp": 1647609600  // 过期时间戳
  },
  "signature": "..." // 使用密钥签名的数据
}

当用户发送后续请求时:

  1. 用户在请求头中携带此 token
  2. 服务器接收请求,验证 token 的签名
  3. 如果签名有效且未过期,则从 token 中直接提取用户信息
  4. 服务器不需要查询数据库就能知道这是用户 12345,拥有管理员权限

整个过程中,服务器不需要存储任何与此 token 相关的信息,所有需要的数据都包含在 token 本身中,这就是所谓的"无状态"。

6. 如何选择?

  • Cookie: 适合需要自动发送数据的场景(如登录状态、跟踪)。
  • Session: 适合需要服务器端存储敏感数据的场景(如用户权限、临时数据)。
  • Token: 适合无状态、跨域的场景(如 RESTful API、单点登录)。
    在实际开发中,可以根据需求选择单一机制或结合使用。例如,用 Cookie 存储 Token,既能利用 Cookie 的自动发送特性,又能享受 Token 的无状态优势。
原文地址:https://blog.csdn.net/m0_46335150/article/details/146454534
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.kler.cn/a/598901.html

相关文章:

  • 哈尔滨工业大学DeepSeek公开课人工智能:大模型原理 技术与应用-从GPT到DeepSeek|附视频下载方法
  • Sql Server数据迁移易错的地方
  • HarmonyOS Next~鸿蒙系统功耗优化体系解析:前台交互与后台任务的全场景节能设计
  • 红数码影视(RED Digital Cinema)存储卡格式化后的恢复方法
  • AF3 rot_matmul 和 rot_vec_mul函数解读
  • 跨平台数据集成:从SQLServer到MySQL的高效实践
  • QT 图表(拆线图,栏状图,饼状图 ,动态图表)
  • Python散点密度图(Scatter Density Plot):数据可视化的强大工具
  • SysVinit和Systemd的系统运行级别
  • others-rustdesk远程
  • 卷积神经网络(Convolutional Neural Network,CNN)
  • c++二分查找模板
  • 【详细解决】pycharm 终端出现报错:“Failed : 无法将“Failed”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。
  • 爬虫案例-爬取某站视频
  • 13、STL中的unordered_set使用方法
  • 单片机写的小液晶屏驱动+汉字滚屏
  • 前端性能优化利器:CDN 技术详解与实战
  • Elasticsearch未授权访问漏洞
  • Redis Cluster 详解
  • MTKAndroid12 解决SystemUI下拉框中,长按WIFI图标会导致崩溃问题