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

  • 定义:客户端存储的小块数据,用于记住用户信息。
  • 特点
    • 随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的一种实现,具有高可移植性和可扩展性。
相关推荐
Volunteer Technology2 分钟前
Spring AI MCP案例
java·开发语言·数据库
紫琪软件工作室5 分钟前
SpringBoot Java邮件发送工具类
java·spring boot·spring
郝学胜-神的一滴5 分钟前
干货版《算法导论》04:渐近复杂度与序列接口实战
java·开发语言·数据结构·c++·python·算法
2301_811130548 分钟前
【保姆级教程】Android Studio完整安装步骤(2026最新版,新手零踩坑)
android·java
_Evan_Yao9 分钟前
缓存与数据库的“双写悖论”:一致性的常见陷阱与破局之道
java·后端·缓存
超梦dasgg25 分钟前
Sentinel生产环境实战全解
java·微服务·sentinel
青云计划28 分钟前
MySQL技术文档
java·mysql
qq_25183645728 分钟前
基于java 汽车检修管理系统设计与实现 论文
java·开发语言·汽车
量子炒饭大师32 分钟前
【Linux系统编程】Cyberpunk在霓虹丛林中构建堡垒 ——【基础开发工具(1)】一文带你初步了解 软件包管理器 并 快速上手 yum和apt 工具
java·linux·运维·apt·yum·软件包管理器
Finger#0000FF37 分钟前
从零上手VibeCoding(ClaudeCode+DeepSeek V4.Pro)
java·人工智能·ai编程·vibe coding·claudecode