news 2026/5/11 23:05:43

什么是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/5/11 5:43:20

BetterNCM插件管理器终极指南:一键解锁网易云音乐隐藏功能

BetterNCM插件管理器终极指南&#xff1a;一键解锁网易云音乐隐藏功能 【免费下载链接】BetterNCM-Installer 一键安装 Better 系软件 项目地址: https://gitcode.com/gh_mirrors/be/BetterNCM-Installer 想要让你的网易云音乐变得更加强大吗&#xff1f;BetterNCM-Inst…

作者头像 李华
网站建设 2026/5/5 16:53:29

FUXA项目中MQTT数据同步问题的完整排查与解决方案

FUXA项目中MQTT数据同步问题的完整排查与解决方案 【免费下载链接】FUXA Web-based Process Visualization (SCADA/HMI/Dashboard) software 项目地址: https://gitcode.com/gh_mirrors/fu/FUXA FUXA作为一款基于Web的SCADA/HMI/Dashboard软件&#xff0c;通过MQTT协议实…

作者头像 李华
网站建设 2026/5/11 0:02:41

8、UNIX系统文件系统与网络安全防护指南

UNIX系统文件系统与网络安全防护指南 1. 文件系统安全基础 在UNIX系统中,文件系统安全至关重要。为了确保系统安全,许多涉及文件搜索的操作需要以超级用户身份运行,因为没有超级用户权限,命令无法搜索受保护的目录,这可能让入侵者轻易隐藏文件。 2. find命令的使用 fi…

作者头像 李华
网站建设 2026/5/5 20:33:46

ComfyUI BrushNet节点安装疑难解答:轻松解决依赖版本冲突问题

ComfyUI BrushNet节点安装疑难解答&#xff1a;轻松解决依赖版本冲突问题 【免费下载链接】ComfyUI-BrushNet ComfyUI BrushNet nodes 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI-BrushNet ComfyUI-BrushNet作为一款功能强大的图像修复与替换插件&#xff0c…

作者头像 李华
网站建设 2026/5/11 1:49:20

React Native轮播组件实战指南:打造高性能移动端轮播体验

React Native轮播组件实战指南&#xff1a;打造高性能移动端轮播体验 【免费下载链接】react-native-snap-carousel 项目地址: https://gitcode.com/gh_mirrors/rea/react-native-snap-carousel react-native-snap-carousel作为React Native生态中最受欢迎的轮播解决方…

作者头像 李华