什么是Token,Token和Session以及Cookie的区别

Token

Token 是一种无状态的认证机制,通常由服务器生成并返回给客户端。客户端在后续请求中携带 Token(如放在 HTTP 头部),服务器通过验证 Token 的合法性来判断用户身份。常见的 Token 类型包括 JWT(JSON Web Token)。

Session

Session 是一种有状态的服务器端存储机制。服务器为每个用户创建一个唯一的 Session ID,存储在服务器内存或数据库中,并将 Session ID 通过 Cookie 或 URL 传递给客户端。客户端在后续请求中携带 Session ID,服务器通过 ID 查找对应的用户数据。

Cookie

Cookie 是存储在客户端(浏览器)的小型文本数据,由服务器通过 HTTP 响应头(Set-Cookie)设置。客户端在后续请求中自动携带 Cookie,用于维持用户状态或存储偏好设置。


三者的主要区别

存储位置

  • Token:通常存储在客户端(如 localStorage 或 HTTP 头部)。
  • Session:Session 数据存储在服务器端,仅 Session ID 通过 Cookie 或 URL 传递。
  • Cookie:数据完全存储在客户端。

状态管理

  • Token:无状态,服务器无需存储 Token,仅需验证其有效性。
  • Session:有状态,服务器需维护 Session 存储。
  • Cookie:无状态,但依赖客户端存储。

安全性

  • Token:可通过加密(如 JWT 签名)确保安全性,但需防范 XSS 攻击。
  • Session:Session ID 易受 CSRF 攻击,需配合防护措施。
  • Cookie:需设置 HttpOnlySecure 属性防范 XSS 和中间人攻击。

扩展性与性能

  • Token:适合分布式系统,无需服务器存储状态。
  • Session:服务器需维护 Session 存储,扩展性较差。
  • Cookie:适合简单状态管理,但数据大小受限(通常 ≤4KB)。

典型应用场景

Token

  • RESTful API 认证(如 JWT)。
  • 移动端或无 Cookie 环境(如跨域请求)。

Session

  • 传统 Web 应用(如电商购物车)。
  • 需服务器端控制用户状态的场景。

Cookie

  • 记住登录状态(如 remember_me 功能)。
  • 存储用户偏好(如语言、主题)。

技术实现示例

Token(JWT)

客户端在登录后获取 Token,后续请求通过 Authorization 头部携带:

http 复制代码
Authorization: Bearer <JWT_TOKEN>

Session

服务器生成 Session ID 并通过 Cookie 返回:

http 复制代码
Set-Cookie: sessionid=abc123; Path=/; HttpOnly

Cookie

服务器设置 Cookie:

http 复制代码
Set-Cookie: username=john; Expires=Wed, 21 Oct 2025 07:28:00 GMT; Secure
相关推荐
一嘴一个橘子19 分钟前
spring-aop 的 基础使用 - 4 - 环绕通知 @Around
java
小毅&Nora35 分钟前
【Java线程安全实战】⑨ CompletableFuture的高级用法:从基础到高阶,结合虚拟线程
java·线程安全·虚拟线程
冰冰菜的扣jio36 分钟前
Redis缓存中三大问题——穿透、击穿、雪崩
java·redis·缓存
小璐猪头1 小时前
专为 Spring Boot 设计的 Elasticsearch 日志收集 Starter
java
ps酷教程1 小时前
HttpPostRequestDecoder源码浅析
java·http·netty
闲人编程1 小时前
消息通知系统实现:构建高可用、可扩展的企业级通知服务
java·服务器·网络·python·消息队列·异步处理·分发器
栈与堆1 小时前
LeetCode-1-两数之和
java·数据结构·后端·python·算法·leetcode·rust
OC溥哥9992 小时前
Paper MinecraftV3.0重大更新(下界更新)我的世界C++2D版本隆重推出,拷贝即玩!
java·c++·算法
星火开发设计2 小时前
C++ map 全面解析与实战指南
java·数据结构·c++·学习·算法·map·知识
*才华有限公司*2 小时前
RTSP视频流播放系统
java·git·websocket·网络协议·信息与通信