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

一文搞懂 Cookie、Session 和 Token 的区别

背景在 Web 应用中HTTP 是无状态协议服务器无法自动识别用户身份。为了实现用户登录状态的保持与身份认证需要引入 Cookie、Session 和 Token 等机制来在多次请求之间维持用户状态CookieCookie 是存储在客户端浏览器的一小段数据会在每次请求时自动携带到服务器。特点有如下自动发送容量小4KB可以被 JS 读取除非 HttpOnlyCookie 的结构长什么样子一个典型的 CookieSet-Cookie:sessionIdabc123;Path/;Domainexample.com;HttpOnly;Secure;SameSiteStrict存储的核心数据是用键值对的形式name value 比如sessionId abc123。其次Domain作用域 Domainexample.com 哪些域名可以使用这个 Cookie。.example.com 子域名也能用a.example.com 仅该子域。Path/ 表示哪些路径能够携带这些cookieExpires / Max-Age过期时间HttpOnly安全设置这个JS 不能访问,document.cookie ❌读不到能够防止 XSS 偷 CookieSecure安全只在HTTPS下发送SameSite, 防止CSRFCookie的工作流程第一次请求浏览器 - 服务器发送get/post请求服务器返回 Set-Cookie: sessionIdabc123后续请求浏览器自动带上 Cookie: sessionIdabc123Cookie的常见用途cookie可以用来存储如下登录状态sessionId用户偏好语言/主题购物车追踪用户行为埋点/广告Cookie 存在的问题Cookie 存在以下几个主要问题首先是容量和数量限制单个 Cookie 大约 4KB且每个域名数量有限其次是作用域受 Domain 和 Path 限制无法跨域使用第三是浏览器会自动携带 Cookie容易导致 CSRF 攻击另外 Cookie 存储在客户端存在被篡改的风险同时如果未设置 HttpOnly可能被 XSS 攻击窃取最后在非 HTTPS 场景下Cookie 还可能被窃听。因此在实际开发中需要结合 HttpOnly、Secure、SameSite 等属性来增强安全性。Cookie总结Cookie 是由服务器设置并存储在客户端浏览器的一小段键值对数据会在后续请求中自动携带到服务器。它常用于维持会话状态例如存储 sessionId。Cookie 具有 Domain、Path、Expires、HttpOnly、Secure 和 SameSite 等属性用于控制作用范围和安全性。Cookie 的主要问题包括容量和数量限制、受同域策略限制、浏览器自动发送容易导致 CSRF 攻击以及可能被 XSS 窃取或被用户篡改。因此在实际开发中通常会结合 HttpOnly、Secure 和 SameSite 等属性来提升安全性。SessionSession 是服务器用来记录用户状态的数据服务器用来记录用户状态的数据通过 Cookie 中的 sessionId 来识别用户。Session 里面通常存储什么首先就是用户身份信息{userId:1001,username:zhangsan}登录状态{isLogin:true}权限信息{role:admin,permissions:[read,write]}Session存储在哪里内存直接存储在服务器的内存中但是这样重启就消失了数据库Mysql等这样能够持久化但是相对性能会差一些Redis(最常用), 高性能支持过期时间分布式支持Session流程 登录时用户登录, 服务器创建 Session{sessionId:abc123,userId:1001}返回 CookieSet-Cookie: sessionIdabc123 后续请求浏览器带 CookieCookie:sessionIdabc123服务器查 Session获取用户信息 ✔Session 存在的问题占用服务器资源每个用户都需要存储不利于分布式在多台服务器的时候用户请求 → 服务器A有Session 下一次 → 服务器B没有Session ❌依赖cookie仍然有CSRF的风险Session总结Session 是服务器端用于存储用户状态的数据结构通常以键值对形式存在通过 Cookie 中的 sessionId 来进行关联。Session 中一般会存储用户身份信息、登录状态、权限信息以及一些临时业务数据。为了提高性能和支持分布式系统Session 通常会存储在内存或 Redis 中。TokenToken 是一种用于身份认证的凭证由服务器生成并返回给客户端客户端在后续请求中携带该凭证来证明自己的身份。Token的工作流程 登录阶段用户登录服务器验证账号密码 ✔生成 Token例如 JWT返回给客户端 后续请求客户端每次请求带上Authorization: Bearer token 服务器验证 Token ✔ 通过 → 返回数据JWT(最常见的token)Json web token是目前最常见的方式Jwt由三部分组成Header.Payload.SignatureHeader头部用来描述加密算法{alg:HS256,typ:JWT}Payload存用户信息{userId:1001,username:zhangsan,exp:1710000000}Signature用密钥生成防止被篡改HMACSHA256(base64(header).base64(payload),secret)Token的特点优点❌ 无需服务器存储无状态✔ 支持分布式天然适合微服务✔ 跨域友好前后端分离必备✔ 性能好不用查数据库缺点❗一旦泄露 → 无法立即失效❗Payload 可被解码不能放敏感信息❗需要手动管理不像 Cookie 自动发送Token的安全问题XSS → 偷 Token如果存localStorage ❌ JS 可以拿到Token 泄露 被截获就能用防御措施使用 HTTPS ✔设置过期时间exp✔使用 Refresh Token ✔不在 Payload 放敏感信息 ✔Token总结Token 是一种用于身份认证的凭证通常由服务器生成并返回给客户端客户端在后续请求中通过 Authorization 头携带 Token 来完成身份验证。常见实现是 JWT它由 Header、Payload 和 Signature 三部分组成。相比 SessionToken 具有无状态、易扩展的特点适用于前后端分离和分布式系统但需要注意 Token 泄露和过期管理等安全问题。

相关文章:

一文搞懂 Cookie、Session 和 Token 的区别

背景 在 Web 应用中,HTTP 是无状态协议,服务器无法自动识别用户身份。为了实现用户登录状态的保持与身份认证,需要引入 Cookie、Session 和 Token 等机制来在多次请求之间维持用户状态 Cookie Cookie 是存储在客户端(浏览器&#…...

Google 迎来「DeepSeek 时刻」:TurboQuant算法实现bit无损、×加速、×压缩、零预处理揪

从 UI 工程师到 AI 应用架构者 13 年前,我的工作是让按钮在 IE6 上对齐; 13 年后,我用 fetch-event-source 订阅大模型的“思维流”,用 OCR 解锁图片中的文字——前端,正在成为 AI 产品的第一道体验防线。 最近&#x…...

多租户下的ERP系统的仓储管理模块分析设计延

springboot自动配置 自动配置了大量组件,配置信息可以在application.properties文件中修改。 当添加了特定的Starter POM后,springboot会根据类路径上的jar包来自动配置bean(比如:springboot发现类路径上的MyBatis相关类&#xff…...

PFC(Power Factor Correction,功率因数校正)

PFC电路的用处用处1:迫使电流与电压同相位,使得用电设备对于电网而言相当于纯阻性负载。当负载呈感性时:电流滞后电压;呈容性时:电流超前电压功率因数越大(接近1.0)说明设备性能越好&#xff0c…...

【赵渝强老师】崖山数据库的体系架构

YashanDB数据库中有数据库和数据库实例这两个基本的概念,并且从体系架构的组成上看,YashanDB数据库又分为了存储结构、进程线程结构和内存结构。因此,要掌握YashanDB的体系架构就需要从数据库与数据库实例入手,并进一步深入到其内…...

亚马逊停止旧款 Kindle 支持,用户与市场面临新变局

2026 年旧款 Kindle 告别 Kindle 商店亚马逊宣布从 2026 年 5 月 20 日起,停止对 2013 年前发布的 Kindle 电子阅读器和 Fire 平板电脑的支持。届时,这些设备将无法访问 Kindle 商店,不能借阅、购买或下载新书籍,但仍可阅读设备上…...

GraalVM Native Image内存优化实战手册(含JDK21+GraalVM24.1插件全链路安装避坑清单)

第一章:GraalVM Native Image内存优化实战手册导论GraalVM Native Image 将 Java 应用提前编译为独立的本地可执行文件,显著降低启动延迟与运行时内存开销。然而,默认构建的 native image 常因反射、动态代理、资源加载等隐式依赖而保留大量未…...

小而强,Meta推出超级智能实验室首款AI模型Muse Spark

文章目录前言二、啥是Muse Spark?说白了就是个"会思考的小机灵鬼"三、"小而强"到底是啥意思?四、不止会聊天,还会"看图说话"五、专门请了1000个医生来"教"它六、从"开源先锋"到"闭源…...

C# 面试高频题:装箱和拆箱是如何影响性能的?伟

OCP原则 ocp指开闭原则,对扩展开放,对修改关闭。是七大原则中最基本的一个原则。 依赖倒置原则(DIP) 什么是依赖倒置原则 核心是面向接口编程、面向抽象编程, 不是面向具体编程。 依赖倒置原则的目的 降低耦合度&#…...

Unity发布京东小游戏圃

从 UI 工程师到 AI 应用架构者 13 年前,我的工作是让按钮在 IE6 上对齐; 13 年后,我用 fetch-event-source 订阅大模型的“思维流”,用 OCR 解锁图片中的文字——前端,正在成为 AI 产品的第一道体验防线。 最近&#x…...

技术分享 | MySQL 8.0复制架构主从自动切换脚本

在技术领域,我们常常被那些闪耀的、可见的成果所吸引。今天,这个焦点无疑是大语言模型技术。它们的流畅对话、惊人的创造力,让我们得以一窥未来的轮廓。然而,作为在企业一线构建、部署和维护复杂系统的实践者,我们深知…...

Java原生镜像内存优化实战手册(含AOT编译期内存剖分图谱):从386MB→47MB的7次关键裁剪记录

第一章:Java原生镜像内存优化全景图谱Java 原生镜像(Native Image)通过 GraalVM 的 AOT(Ahead-of-Time)编译技术,将 Java 字节码直接编译为平台原生可执行文件,在启动速度、内存占用和资源效率方…...

​有机溶剂回收设备厂家实测

测评主体公示本次测评对象包括:可迪尔、蓝太克、英飞、艾科,以及有机溶剂回收设备厂家(选取三家技术路径不同的具体设备:厂家A‑活性炭吸附型、厂家B‑沸石转轮浓缩型、厂家C‑冷凝回收型)。 统一测评维度:…...

仅限首批200名开发者获取:Java 25虚拟线程高并发架构迁移评估工具包(含代码扫描器+风险热力图+ROI预测模型)

第一章:Java 25虚拟线程高并发架构迁移全景认知Java 25正式将虚拟线程(Virtual Threads)从预览特性转为标准特性,标志着JVM并发模型进入轻量级、高密度、低开销的新纪元。虚拟线程基于Project Loom多年演进,以java.lan…...

案例分析:学术文献综述 Agent Harness

案例分析:学术文献综述 Agent Harness——从手动“文献堆沙”到智能“知识城堡”的AI构建器关键词:学术文献综述 Agent、Agent Harness、多智能体协作、大语言模型应用、学术自动化、知识图谱构建、文献检索-筛选-总结流水线摘要:本文以Chatb…...

从田间到大屏只要1.8秒:PHP异步任务队列+Redis流式渲染农业可视化看板(实测QPS 1270+)

第一章:从田间到大屏只要1.8秒:PHP异步任务队列Redis流式渲染农业可视化看板(实测QPS 1270)在智慧农业场景中,传感器集群每秒上报数千条温湿度、土壤EC值、光照强度等时序数据,传统同步渲染方式导致看板平均…...

PHP容器化落地国产化替代的最后1公里:从Docker镜像构建、OpenEuler适配到等保2.0合规部署(含12项硬性检测项)

第一章:PHP容器化部署国产化适配方案在信创背景下,PHP应用需适配国产操作系统(如统信UOS、麒麟V10)、国产CPU架构(鲲鹏、飞腾、海光、兆芯)及国产中间件生态。容器化是实现跨平台一致部署与国产环境快速迁移…...

环境变量-代理/PowerShell乱码

设置代理[Environment]::SetEnvironmentVariable(HTTP_PROXY, socks5://127.0.0.1:5800, User) [Environment]::SetEnvironmentVariable(HTTPS_PROXY, socks5://127.0.0.1:5800, User) [Environment]::SetEnvironmentVariable(ALL_PROXY, socks5://127.0.0.1:5800, User) Write…...

NVIDIA Profile Inspector:深度优化显卡性能的游戏技术解决方案

NVIDIA Profile Inspector:深度优化显卡性能的游戏技术解决方案 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector 在游戏运行过程中,用户常常面临帧率不稳定、画面撕裂、输入延迟高…...

南京道尔斯特机架式PDU重新定义工业级安全电源管理新范式

在数字化基建加速迭代、工业互联网深度渗透的现在,电力分配作为工业数字底座的关键枢纽,其安全性、可靠性与智能化水平​行业痛点凸显:传统电源方案难以适配工业高负载场景刚需​当前,随着GPU服务器、工业PLC、精密医疗设备等大功…...

手机扩大屏定制厂家:菲涅尔高清模压技术护航跨境出海

在跨境电商快速发展的如今,手机屏幕放大器作为移动配件领域的细分品类,正在成为全球卖家关注的焦点。然而,货源不稳定、产品同质化、知识产权风险、镜片清晰度不佳等行业痛点,始终困扰着跨境电商从业者。如何找到一家技术过硬、供…...

Yu-AI-Agent 项目(AI 恋爱大师智能体) · 学习笔记

Yu-AI-Agent 项目(AI 恋爱大师智能体) 学习笔记 本项目是 AI 超级智能体 项目的 Java 前后端部分,学习自 鱼皮 编程导航 的 AI 开发实战课程及开源代码仓库。 基于 Spring Boot 3 Java 21 Spring AI 构建了 AI 恋爱大师应用与 ReAct 模式…...

如何释放CPU全部潜能:CPUDoc智能优化工具完全指南

如何释放CPU全部潜能:CPUDoc智能优化工具完全指南 【免费下载链接】CPUDoc 项目地址: https://gitcode.com/gh_mirrors/cp/CPUDoc 你是否经常感觉电脑性能未能充分发挥?明明配置不错的硬件,却在运行大型软件或游戏时出现卡顿&#xf…...

【Hot 100 刷题计划】 LeetCode 74. 搜索二维矩阵 | C++ 二分查找 (一维展开法)

LeetCode 74. 搜索二维矩阵 📌 题目描述 题目级别:中等 给你一个满足下述两条属性的 m x n 整数矩阵: 每行中的整数从左到右按非严格递增顺序排列。每行的第一个整数大于前一行的最后一个整数。 给你一个整数 target ,如果 target…...

凌晨 6 点,裁员 3 万:AI时代最残酷的一幕来了

3月31日凌晨6点,很多甲骨文(Oracle)员工还在睡梦中,手机突然亮了。一封来自“Oracle Leadership”(甲骨文管理层)的邮件,只有短短几句话:“经过仔细评估公司当前业务需要&#xff0c…...

【Loom生产环境禁用清单】:这7个Spring Boot自动配置项正在 silently 杀死你的虚拟线程吞吐量

第一章:Java 25虚拟线程在高并发架构下的性能本质洞察Java 25正式将虚拟线程(Virtual Threads)从预览特性转为标准特性,标志着JVM并发模型的一次范式跃迁。其性能本质不在于单线程执行速度的提升,而在于**线程生命周期…...

基于Matlab Simulink的储能系统变换模型与钒液流电池仿真研究:功能实现及效果展示

基于Matlab/Simulink实现了以下功能,搭建了储能系统变换模型以及钒液流电池模型,仿真效果较好,系统充放电正常。 下图为系统模型图,电池输出电压电流以及SOC波形。 1.钒液流电池本体建模 2.储能变换器建模 3.双向DC变换 4.恒定功率…...

最近在折腾输电线路单相接地故障测距,发现小波变换模极大值双端行波法挺有意思。自己用Matlab/Simulink搭了个模型,今天拆开揉碎了说说实现细节

Matlab小波变换模极大值双端行波测距凯伦布尔变换输电线路单相接地故障测距Simulink模型及对应程序。 自己搭的模型,写的程序(带注释),配有对应详细算例说明,适合初学者学习。先看模型框架:双端行波法需要在…...

深入理解Kubernetes网络模型:摆脱“配置工程师”噩梦

在云原生测试领域,Kubernetes已成为基础设施的核心载体。然而,网络配置的复杂性常使测试人员陷入“反复调参-验证失败”的循环。本文从测试视角解析Kubernetes网络模型,提供可落地的验证方法论,帮助测试工程师突破网络瓶颈&#x…...

边缘计算与AI推理:在终端设备上部署模型的挑战

边缘AI部署的测试价值重构随着AI推理任务从云端下沉至终端设备,软件测试的战场正经历根本性变革。边缘计算通过将模型部署于摄像头、工业传感器、车载终端等设备,实现了毫秒级响应的实时决策能力。据行业预测,2026年全球边缘AI设备市场规模将…...