Cookie、Session、Token、JWT 概念与区别

devtools/2024/12/22 9:28:57/

Cookie

  • 定义客户端存储的小块数据,用于记住用户信息。
  • 特点
    • 随HTTP请求发送给服务器。
    • 可设置过期时间。
    • 存储容量有限,约4KB。

Session

  • 定义:服务器端存储的会话状态记录。
  • 特点
    • 与会话ID关联,通常通过Cookie发送给客户端
    • 可存储更多信息,包括敏感信息。

Token

  • 定义:无状态认证的安全令牌。
  • 特点
    • 客户端持有,用于请求认证。
    • 不要求服务器跟踪状态。

JWT (JSON Web Tokens)

  • 定义:基于JSON的轻量级认证机制。
  • 特点
    • 包含头部、负载和签名。
    • 自包含所有验证信息。

二、安全性与跨域支持

安全性

  • Cookie:较低,易被窃取或篡改。
  • Session:较高,数据不在客户端暴露。
  • Token/JWT:较高,特别是JWT包含签名。

跨域支持

  • Cookie:默认不支持,可通过设置实现。
  • Session:不支持,依赖Cookie。
  • Token/JWT:支持,不依赖Cookie。

三、实战应用与Spring Boot 示例

Spring Boot 示例

  • 设置Cookie:通过Set-Cookie头部设置。
  • 设置Session:通过getSession方法设置。
  • 生成Token:使用JWT库生成。

安全措施

  • 使用HTTPS。
  • 密钥管理,不硬编码,使用专业系统。
  • 防止CSRF攻击,使用POST请求和CSRF令牌。

四、最佳实践与安全措施

添加依赖项

  • Spring Security和JWT依赖项添加到pom.xml

JWT工具类

  • 生成和验证JWT的方法。

控制器

  • 处理登录请求,生成JWT。

Spring Security配置

  • 配置使用JWT进行认证。

其他安全措施

  • 定期更新框架和库。
  • 实施输入验证和输出编码。
  • 限制密码尝试次数,防止暴力破解。

五、适用场景

  • Cookie:简单会话跟踪,用户偏好设置。
  • Session:需要服务器记住用户状态的场景。
  • Token:移动应用、API身份验证、跨域请求。
  • JWT:Web应用、移动应用、单点登录。

六、总结

  • Cookie和Session是传统的会话管理机制。
  • Token和JWT提供更灵活和安全的身份验证和授权机制,适用于分布式系统。
  • JWT作为Token的一种实现,具有高可移植性和可扩展性。

http://www.ppmy.cn/devtools/58181.html

相关文章

Linux 常用指令详解

Linux 是一个强大而灵活的操作系统,掌握常用的 Linux 指令是使用和管理 Linux 系统的基础。本文将介绍一些常用的 Linux 指令,并附上 Vim 和 g 的常用指令说明,帮助你更好地进行开发和操作。 1. 基本文件操作指令 1.1 显示目录内容 ls常用…

react v18 less使用(craco)

方案一、弹出配置(不推荐) 安装依赖:yarn add less less-loader 首先 执行 yarn eject 弹出配置项文件(注意:弹出配置不可逆!) 在 config 文件夹中 找到 webpack.config.js,在如图…

PostgreSQL 如何优化存储过程的执行效率?

文章目录 一、查询优化1. 正确使用索引2. 避免不必要的全表扫描3. 使用合适的连接方式4. 优化子查询 二、参数传递1. 避免传递大对象2. 参数类型匹配 三、减少数据量处理1. 限制返回结果集2. 提前筛选数据 四、优化逻辑结构1. 分解复杂的存储过程2. 避免过度使用游标 五、事务处…

面试知识点【java基础篇】

1、一个程序有且仅有一个main方法启动,main方法是作为java程序启动的唯一入口。 public static void main(String[] args) {Student student new Student(11,"111");System.out.println(student);} 权限修饰符:public:修饰一个类是公开的 pub…

Knife4j的原理及应用详解(一)

本系列文章简介: 在当今快速发展的软件开发领域,API(Application Programming Interface,应用程序编程接口)作为不同软件应用之间通信的桥梁,其重要性日益凸显。随着微服务架构的兴起,API的数量…

论文引用h指数

文章目录 1、描述2、关键字3、思路4、notes5、复杂度6、code 1、描述 给你一个整数数组 citations ,其中 citations[i] 表示研究者的第 i 篇论文被引用的次数。计算并返回该研究者的 h 指数。 根据维基百科上 h 指数的定义:h 代表“高引用次数” &…

AI和人工智能是啥关系?

AI(人工智能)与通用人工智能(AGI)是人工智能领域中的两个重要概念,它们在定义、技术基础以及应用领域等方面有所区别。人工智能(AI),是指使计算机和其他机器模拟人类智能的技术&…

Python面试题:如何在 Python 中实现单例模式?

在 Python 中,有多种方法可以实现单例模式(Singleton Pattern)。单例模式是一种设计模式,确保一个类只有一个实例,并提供一个全局访问点。以下是几种常见的方法来实现单例模式: 方法一:使用类变…