当前位置: 首页 > article >正文

Cookie、Session、Token 详细讲解

Cookie、Session、Token这三个是Web 身份认证、会话管理的核心技术核心围绕「用户登录后怎么证明你是你」展开。先给一个最通俗的比喻Cookie酒店给你的房卡贴纸你自己揣着每次进房间出示Session酒店前台的登记本你只带一个编号前台查本子确认你身份Token酒店给你的盖章通行证自己拿着保安看章就放行不用查本子一、分别详解定义 原理 特点1. Cookie本质服务器通过响应头Set-Cookie发给浏览器的小型文本数据纯客户端存储。核心原理服务器生成 Cookie → 响应头返回给浏览器浏览器自动保存 Cookie本地文件 / 缓存后续请求同一域名时浏览器自动携带Cookie 到服务器服务器解析 Cookie识别用户关键特点存储位置客户端浏览器大小限制单 Cookie≈4KB单个域名最多 20 个左右生命周期会话 Cookie关闭浏览器即失效持久 Cookie服务器设置max-age/expires到期失效传输方式自动携带无需前端手动处理安全性明文存储可加密易被 XSS/CSRF 攻击状态无状态服务器不保存任何 Cookie 相关数据常用场景记住用户名、购物车、主题偏好、广告追踪等轻量、非敏感数据。2. Session本质服务器端的会话数据基于 Cookie 实现核心依赖SessionID服务端存储。核心原理用户登录成功服务器创建Session存储用户信息用户 ID、权限等生成唯一SessionID通过 Cookie 返回给浏览器后续请求浏览器自动带SessionID的 Cookie服务器通过SessionID查询本地 Session 数据确认用户身份关键特点存储位置服务器端内存、Redis、数据库大小限制无严格限制取决于服务器资源生命周期会话超时 / 关闭浏览器 / 主动登出失效传输方式依赖 Cookie 传递SessionID安全性数据在服务器仅 ID 在客户端比 Cookie 安全状态有状态服务器需要维护所有用户的 Session缺陷分布式 / 集群环境下Session 共享麻烦需 Redis 同步常用场景传统单体 Web 应用的用户登录会话管理。3. Token以 JWT 为例最常用本质加密签名的身份凭证无状态认证服务器不存储会话数据。常见JWTJSON Web Token、OAuth2 Token。核心原理用户登录成功服务器用密钥加密生成 Token包含用户信息 过期时间 签名Token 返回给前端前端存在LocalStorage/SessionStorage/Cookie后续请求前端手动把 Token 放到请求头Authorization: Bearer xxx服务器验签解密 Token无需查询数据库 / 缓存直接识别用户关键特点存储位置客户端LocalStorage、Cookie、移动端本地大小限制大于 Cookie取决于载荷内容生命周期服务器签发时固定过期时间无法主动作废除非加黑名单传输方式手动携带不自动随请求发送安全性加密签名防篡改CSRF 风险极低XSS 仍需防护状态无状态服务器不存任何会话天然支持分布式优势跨域友好、支持移动端 / 小程序 / 微服务常用场景前后端分离、App / 小程序、分布式微服务、跨域认证。二、核心区别对比表表格维度CookieSessionTokenJWT存储位置客户端浏览器服务器端客户端是否依赖 Cookie本身就是 Cookie依赖 Cookie 传递 SessionID不依赖可存 Cookie / 本地存储服务端状态无状态有状态需维护会话无状态分布式 / 集群支持支持麻烦需 Session 共享天然支持跨域支持受同源策略限制受同源策略限制极佳请求头携带跨域无压力传输方式浏览器自动携带自动携带 SessionID前端手动放入请求头安全性低明文易劫持中数据在服务端高加密签名防篡改性能开销小中服务端存储 查询小仅验签无查询数据大小小≈4KB大中等三、关键核心差异总结1. 存储位置决定「谁管数据」Cookie客户端管服务器不管Session服务器管客户端只存 IDToken客户端管服务器只负责验签2. 状态性决定「分布式适配」Session 是有状态服务器必须记住每个用户的会话集群下要同步 Session成本高Cookie/Token 是无状态服务器不记会话随便扩容适配微服务3. 传输方式决定「跨域 CSRF」Cookie 自动携带同源限制严易被 CSRF 攻击Token 手动携带跨域自由CSRF 风险几乎为 04. 安全性排序TokenJWT Session Cookie四、演进关系为什么会从 Cookie→Session→Token早期只用 Cookie直接存用户信息但明文不安全、大小受限改用 Session把敏感数据放服务端只留 ID 在 Cookie解决安全问题出现 Token解决 Session 在分布式、跨域、移动端的痛点无状态更灵活五、适用场景选择用 Cookie存非敏感轻量数据记住账号、购物车、主题用 Session传统单体网站、内网系统无需跨域 / 分布式用 Token前后端分离、App / 小程序、微服务、第三方登录OAuth2六、补充常见误区Session 必须用 Cookie不是也可以通过 URL 拼接 SessionID但极少用不安全。Token 就是 JWT不是Token 是统称JWT 是最常用的实现方式。Token 绝对安全防篡改但怕 XSS 窃取所以建议配合HttpOnly、Secure、SameSite使用。

相关文章:

Cookie、Session、Token 详细讲解

Cookie、Session、Token 这三个是Web 身份认证、会话管理的核心技术,核心围绕「用户登录后,怎么证明你是你」展开。先给一个最通俗的比喻:Cookie:酒店给你的房卡贴纸,你自己揣着,每次进房间出示Session&…...

如何利用 SEO 优化平台提高网站排名

如何利用 SEO 优化平台提高网站排名 在当前数字化时代,网站排名是吸引流量、提升业务的重要因素。搜索引擎优化(SEO)在这一过程中扮演着不可或缺的角色。本文将详细探讨如何利用 SEO 优化平台来提高网站在搜索引擎中的排名,涵盖问…...

MacBook安装OpenClaw:M系列芯片运行Kimi-VL-A3B-Thinking优化指南

MacBook安装OpenClaw:M系列芯片运行Kimi-VL-A3B-Thinking优化指南 1. 为什么要在M系列MacBook上部署OpenClaw 去年我入手了M2 Max芯片的MacBook Pro,原本只是用来做日常开发,直到发现它能流畅运行多模态大模型。作为一个长期被Windows平台G…...

update_io_latency:为什么你的IO约束会变成负数?

在数字后端CTS阶段,很多同学都困惑过——为什么做完时钟树后,Timing Report里IO Port的clock latency突然变成了负数?景芯训练营仔细的同学都发现了,在Innovus中从ccopt 后的timing report中可以看到clock delay是从负值开始算起的…...

从‘拉风箱’到‘指哪打哪’:VCM音圈马达如何重塑了我们的手机拍照体验?

从‘拉风箱’到‘指哪打哪’:VCM音圈马达如何重塑了我们的手机拍照体验? 还记得十年前用手机拍运动场景的崩溃体验吗?按下快门后镜头反复伸缩发出"咔咔"声,像老式风箱般迟钝,等对焦完成时孩子早已跑出画面。…...

TypeScript类型体操进阶:复杂场景类型推导实战

TypeScript类型体操进阶:复杂场景类型推导实战 在中大型前端项目中,TypeScript的静态类型检查已经成为保障代码健壮性的核心手段。但随着业务复杂度提升,简单的基础类型和接口声明已无法满足动态场景的类型约束需求——比如表单数据的动态校验…...

吊打默认播放器!PotPlayer封神之路:从安装到精通的终极调教指南,看这一篇就够了。

PotPlayer 在 Windows 平台的本地播放器领域,无疑是公认的标杆级应用。 凭借对全格式的原生支持、清爽无广告的体验以及极高的可定制性,常年霸占装机必备榜单。 然而,其默认配置往往保留了较为“硬核”的原厂设定,未能完全发挥软…...

阿里云新用户专享:手把手教你用CentOS 7搭建《我的世界》PaperSpigot服务器(含端口配置与后台运行)

阿里云新用户专享:CentOS 7搭建《我的世界》高性能服务器全攻略 第一次在云服务器上搭建《我的世界》服务器时,我被各种专业术语和命令行操作搞得晕头转向。直到发现阿里云新用户的优惠活动,才意识到原来用不到一顿火锅的钱就能拥有专属游戏…...

开始你的「一人公司」

未来大部分的公司,都将是「一个人 N 个 AI」的模式。 这意味着你不再需要很多前置条件,就能开始交付真正的产品。 阻碍你行动的不再是资金、团队或资源,而更多是——你有没有意愿。一、AI 会让认知成本趋近于零这是最关键的判断。电的出现让…...

用CS5090E芯片给两节锂电池充电,实测效率90%的完整方案(附立创EDA原理图)

基于CS5090E的双节锂电池高效充电方案实战解析 两节锂电池串联充电在便携式设备中越来越常见,但如何实现高效、安全的充电却是个技术活。最近我在一个开源硬件项目中遇到了这个问题,经过反复测试验证,最终采用CS5090E芯片设计了一套充电效率实…...

MySQL索引优化+慢查询全解析

上一篇博客我们讲了MySQL存储引擎和视图的核心考点,今天聚焦开发者最常接触、面试最常考的两大模块——索引优化和慢查询。索引是MySQL的“加速神器”,但用错反而会拖慢性能;慢查询是定位性能瓶颈的关键,掌握其配置和分析方法能快…...

侧信道攻击防御指南:从智能家居到云服务器的7个关键防护措施

侧信道攻击防御指南:从智能家居到云服务器的7个关键防护措施 在数字化浪潮席卷全球的今天,数据安全已成为企业生存的命脉。然而,当大多数安全团队还在与传统的网络攻击周旋时,一种更为隐蔽的威胁正在悄然蔓延——侧信道攻击。这种…...

在WinForms里用OpenTK+SkiaSharp画个会动的波形图(.NET 8环境保姆级教程)

在WinForms里用OpenTKSkiaSharp画个会动的波形图(.NET 8环境保姆级教程) 最近在开发一个实时音频分析工具时,遇到了一个有趣的挑战:如何在Windows Forms应用中高效渲染动态波形图。经过多次尝试,我发现结合OpenTK的Ope…...

Linux内核开发者笔记:ARMv8平台DMA与Cache一致性的三种解法与避坑指南

ARMv8平台DMA与Cache一致性实战指南:从原理到Linux内核实现 在嵌入式Linux开发中,DMA操作与Cache一致性问题是每个驱动开发者都必须面对的经典难题。特别是在ARMv8架构平台上,当DMA控制器直接访问内存而绕过CPU时,Cache中的数据与…...

Arcgis新手必看:如何用线矢量快速提取tif栅格值并绘制专业剖面线图

ArcGIS线矢量提取栅格值实战:从数据到专业剖面图的完整指南 当你第一次面对需要分析地形起伏、温度梯度或任何连续空间数据的变化趋势时,剖面线图无疑是直观展示这些信息的利器。作为ArcGIS平台的核心分析功能之一,线矢量提取栅格值并绘制剖面…...

用libhv从零搭建一个能跑7万QPS的微型HTTP服务器(附完整源码解析)

用libhv构建7万QPS的微型HTTP服务器:工业级性能优化实战 在当今快速迭代的互联网服务开发中,开发者经常面临一个核心矛盾:如何在不牺牲性能的前提下,快速构建可投入生产环境的高并发服务?传统方案往往需要在开发效率与…...

搜索引擎优化(SEO)对网站排名有什么影响

搜索引擎优化(SEO)对网站排名有什么影响 在当今互联网时代,拥有一个成功的网站不仅仅是建立一个美观的网页,更重要的是让这个网站在搜索引擎中获得高排名。搜索引擎优化(SEO)正是为了解决这个问题,让你的网站能够在大…...

Qtile扩展开发终极指南:编写自定义命令和工具的完整教程

Qtile扩展开发终极指南:编写自定义命令和工具的完整教程 【免费下载链接】qtile :cookie: A full-featured, hackable tiling window manager written and configured in Python (X11 Wayland) 项目地址: https://gitcode.com/gh_mirrors/qt/qtile Qtile是一…...

OpenClaw+百川2-13B量化模型:个人知识库自动整理方案实测

OpenClaw百川2-13B量化模型:个人知识库自动整理方案实测 1. 为什么需要自动化知识管理 作为一个长期与技术文档打交道的开发者,我的电脑里堆积着超过200GB的未整理资料——从会议录音转写的文字稿、GitHub扒下来的开源项目说明,到随手保存的…...

SpringBoot多数据源事务隔离级别终极指南:动态数据源配置与分布式事务完全解析

SpringBoot多数据源事务隔离级别终极指南:动态数据源配置与分布式事务完全解析 【免费下载链接】dynamic-datasource dynamic datasource for springboot 多数据源 动态数据源 主从分离 读写分离 分布式事务 项目地址: https://gitcode.com/gh_mirrors/dy/dynami…...

颠覆式闲鱼智能客服系统:家居卖家7×24小时值守零门槛解决方案

颠覆式闲鱼智能客服系统:家居卖家724小时值守零门槛解决方案 【免费下载链接】XianyuAutoAgent 智能闲鱼客服机器人系统:专为闲鱼平台打造的AI值守解决方案,实现闲鱼平台724小时自动化值守,支持多专家协同决策、智能议价和上下文感…...

利用modbus_tcp实现多设备数据聚合:构建高效modbusSlave网关的实践指南

1. 为什么需要Modbus TCP数据聚合网关 在工业自动化现场,我们经常会遇到这样的场景:车间里分散着十几台PLC设备,每台设备都通过Modbus TCP协议暴露数据接口。这时候如果上位机系统要同时监控所有设备,传统做法是逐个建立连接轮询数…...

Linux网络驱动实验

直接参考【正点原子】I.MX6U嵌入式Linux驱动开发指南V1.81 本文仅作为个人笔记使用,方便进一步记录自己的实践总结。 网络驱动是 linux 里面驱动三巨头之一,linux 下的网络功能非常强大,嵌入式 linux 中也常常用到网络功能。前面我们已经讲过…...

HC32F460串口DMA发送中断接收避坑指南:静电干扰、丢字节问题与中断配置详解

HC32F460串口通信实战:DMA发送与中断接收的深度优化指南 在华大HC32F460系列MCU的实际应用中,串口通信作为最基础也最关键的通信接口之一,其稳定性和效率直接影响整个系统的可靠性。不同于STM32等传统MCU的固定中断映射机制,HC32F…...

C++和OpenGL实现3D游戏编程【连载16】——详解三维坐标转二维屏幕坐标(向量和矩阵操作实战)(附源码)

🔥C++和OpenGL实现3D游戏编程【目录】 1、本节课要实现的内容 在上一课我们了解了着色器,了解了部分核心模式编程内容,从中接触到了线性代数中向量和矩阵相关知识,我们已经能够感受到向量和矩阵在OpenGL编程中的重要性。特别是后期用去了解融合、光照效果,构建自己的三维…...

保姆级教程:在RT-Thread Studio中为AT32F437配置LAN8720以太网(从驱动使能到ifconfig测试)

从零构建AT32F437以太网通信:RT-Thread Studio与LAN8720全流程实战指南 当AT32F437这颗高性能MCU遇上RT-Thread的实时操作系统,再配合LAN8720这颗经典的以太网物理层芯片,能碰撞出怎样的火花?作为嵌入式开发者,实现设备…...

避免技术债:Agent 代码库的模块化设计与工程规范

避免技术债:Agent 代码库的模块化设计与工程规范 关键词 Agent技术栈、技术债消解、模块化第一性原理、分层-事件驱动架构、多Agent协作规范、DevOps for AI Agents、可持续迭代工程实践摘要 本文以「Agent代码库的技术债本质」为第一性原理切入点,系统性…...

数据库死锁的排查:从现象到根因

在软件测试工作中,数据库的稳定性和数据一致性是评估系统质量的关键维度。死锁问题,作为数据库并发控制中的“顽疾”,其随机性、隐蔽性和破坏性常常让测试人员感到棘手。它不仅是性能测试中的“拦路虎”,更可能在线上引发严重故障…...

3步搞定OpenClaw镜像体验:Kimi-VL-A3B-Thinking云端沙盒部署

3步搞定OpenClaw镜像体验:Kimi-VL-A3B-Thinking云端沙盒部署 1. 为什么选择云端沙盒体验OpenClaw 作为一个长期在本地折腾各种AI工具的技术爱好者,我深刻理解配置环境的痛苦。记得第一次尝试在MacBook上部署OpenClaw时,光是解决Node.js版本…...

Le Git Graph终极故障排除指南:15个常见问题解决方案大全

Le Git Graph终极故障排除指南:15个常见问题解决方案大全 【免费下载链接】le-git-graph Browser extension to add git graph to GitHub website. 项目地址: https://gitcode.com/gh_mirrors/le/le-git-graph Le Git Graph是一款强大的浏览器扩展&#xff0…...