news 2026/2/18 3:54:59

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
什么是Token,Token和Session以及Cookie的区别

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头部携带:

Authorization: Bearer <JWT_TOKEN>

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

Set-Cookie: sessionid=abc123; Path=/; HttpOnly

Cookie
服务器设置 Cookie:

Set-Cookie: username=john; Expires=Wed, 21 Oct 2025 07:28:00 GMT; Secure
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/11 12:59:54

DROP DELETE 和TRUNCATE的区别?

删除操作的定义与用途DROP 用于删除整个数据库对象&#xff08;如表、视图、索引等&#xff09;&#xff0c;包括其结构和数据。DELETE 用于删除表中的特定行数据&#xff0c;保留表结构。TRUNCATE 用于快速删除表中所有数据&#xff0c;保留表结构并重置自增计数器。事务与日志…

作者头像 李华
网站建设 2026/2/15 21:06:29

5分钟掌握CAN总线工具:Python cantools终极使用指南

5分钟掌握CAN总线工具&#xff1a;Python cantools终极使用指南 【免费下载链接】cantools CAN bus tools. 项目地址: https://gitcode.com/gh_mirrors/ca/cantools 在现代汽车电子和工业控制系统中&#xff0c;CAN总线技术扮演着至关重要的角色。Python cantools库作为…

作者头像 李华
网站建设 2026/2/15 19:41:19

抖音无水印下载:3分钟学会视频本地保存技巧

抖音无水印下载&#xff1a;3分钟学会视频本地保存技巧 【免费下载链接】douyin_downloader 抖音短视频无水印下载 win编译版本下载&#xff1a;https://www.lanzous.com/i9za5od 项目地址: https://gitcode.com/gh_mirrors/dou/douyin_downloader 想要永久保存抖音上的…

作者头像 李华
网站建设 2026/2/12 10:03:29

如何将闲置安卓电视盒子改造成高性能Armbian服务器

如何将闲置安卓电视盒子改造成高性能Armbian服务器 【免费下载链接】amlogic-s9xxx-armbian amlogic-s9xxx-armbian: 该项目提供了为Amlogic、Rockchip和Allwinner盒子构建的Armbian系统镜像&#xff0c;支持多种设备&#xff0c;允许用户将安卓TV系统更换为功能强大的Armbian服…

作者头像 李华
网站建设 2026/2/14 12:36:30

零基础部署智能OCR服务:Docker版OCRmyPDF实战手册

零基础部署智能OCR服务&#xff1a;Docker版OCRmyPDF实战手册 【免费下载链接】OCRmyPDF OCRmyPDF adds an OCR text layer to scanned PDF files, allowing them to be searched 项目地址: https://gitcode.com/GitHub_Trending/oc/OCRmyPDF 还在为堆积如山的扫描文档无…

作者头像 李华
网站建设 2026/2/11 18:53:18

19、加密、认证与安全策略全解析

加密、认证与安全策略全解析 在当今数字化时代,数据安全和用户认证是至关重要的问题。本文将深入探讨加密和认证机制,以及如何制定有效的安全策略来保护计算机系统免受未经授权的访问和滥用。 加密与认证机制 在信息传输过程中,认证和保密是两个关键需求。对于认证,用户…

作者头像 李华