计算机网络——Session、Cookie 和 Token

news2025/12/15 7:52:02

在 Web 开发中,SessionCookieToken 是实现用户会话管理和身份验证的核心技术。它们既有联系,也有明显区别。以下从定义、原理、联系、区别和应用场景等方面详细解析。

一、基本定义与原理

1. Cookie
  • 定义
    是浏览器存储在客户端的小型文本数据(键值对),由服务器生成并发送给浏览器,后续浏览器会自动携带 Cookie 访问同一域名下的资源。
  • 原理
    • 服务器通过响应头 Set-Cookie 发送 Cookie 到浏览器。
    • 浏览器每次请求同一域名时,会在请求头 Cookie 中携带该 Cookie。
    • 可设置过期时间(Expires/Max-Age),默认随浏览器关闭失效。
  • 示例
    Set-Cookie: sessionId=abc123; Expires=Mon, 22 May 2025 12:00:00 GMT; Path=/
    
2. Session
  • 定义
    是服务器端用于存储用户会话数据的临时存储机制,通过 sessionId 与客户端 Cookie 绑定。
  • 原理
    • 用户首次访问时,服务器生成 sessionId 并存储会话数据(如用户信息),同时通过 Cookie 将 sessionId 发送给浏览器。
    • 后续请求中,浏览器携带 sessionId,服务器根据该 ID 查找对应的会话数据。
  • 存储介质
    内存、文件、数据库(如 Redis)等,需考虑服务器集群时的共享问题。
3. Token
  • 定义
    是客户端向服务器证明身份的凭证(通常为加密字符串),由服务器生成并返回给客户端,后续客户端需主动携带 Token 访问资源。
  • 原理
    • 登录时,用户提交凭证(如用户名/密码),服务器验证通过后生成 Token(含用户信息、过期时间等),返回给客户端。
    • 客户端存储 Token(如 localStorage、Cookie),每次请求时在请求头(如 Authorization: Bearer <token>)中携带。
    • 服务器验证 Token 的有效性(如签名、过期时间),无需查询数据库。
  • 常见类型
    • JWT(JSON Web Token):自包含数据(头部、载荷、签名),无需服务器存储。
    • OAuth Token:用于第三方授权(如微信登录)。

二、联系与区别

联系
  1. 均用于会话管理与身份验证
    • Cookie 和 Session 配合使用(Cookie 存储 sessionId,Session 存储用户数据)。
    • Token 可替代传统的 Session-Cookie 模式,实现无状态身份验证。
  2. 数据传递依赖 HTTP 请求
    均通过 HTTP 请求头或 Cookie 传递信息,用于识别用户身份。
区别
维度CookieSessionToken
存储位置客户端(浏览器)服务器端(内存/数据库等)客户端(自定义存储,如 localStorage)
数据性质小型文本数据(键值对)任意类型数据(如对象、数组)加密字符串(自包含数据或引用标识)
状态性有状态(依赖服务器会话存储)有状态(依赖服务器存储)无状态(JWT 自包含数据,无需服务器查询)
安全性较低(易被篡改,需配合 HttpOnly/Secure较高(敏感数据存服务器)高(加密签名,防篡改)
跨域支持受同源策略限制受服务器环境限制(需共享会话存储)灵活(可通过请求头携带,跨域友好)
典型应用存储用户偏好、购物车标识存储用户登录状态、权限信息接口认证(如 RESTful API)、单点登录(SSO)
过期机制客户端控制(通过 Expires/Max-Age)服务器控制(可设置超时时间)客户端与服务器共同控制(Token 自身包含过期时间)

三、核心场景对比

1. 传统 Web 应用(Cookie + Session)
  • 流程
    登录 → 服务器生成 sessionId 和 Session 数据 → 通过 Cookie 返回 sessionId → 后续请求携带 Cookie → 服务器验证 sessionId 并获取用户数据。
  • 优点
    • 服务器可控性强,适合存储敏感信息(如用户权限)。
    • 无需在请求中携带大量数据。
  • 缺点
    • 服务器需维护会话存储,集群环境下需共享存储(如 Redis)。
    • 跨域场景下 Cookie 传递受限。
2. 现代 API 应用(Token 为主)
  • 流程
    登录 → 服务器生成 JWT → 客户端存储 JWT → 每次请求携带 JWT(如请求头 Authorization)→ 服务器验证 JWT 有效性。
  • 优点
    • 无状态,服务器无需存储会话,可横向扩展。
    • 跨域友好,适合前后端分离、移动端、第三方服务调用。
  • 缺点
    • JWT 自身包含数据,若数据量大(如用户权限列表),会增加请求体积。
    • 过期后需重新登录(可通过刷新令牌(Refresh Token)优化)。

四、如何选择?

  1. 优先使用 Cookie + Session 的场景

    • 需要存储大量敏感数据(如用户购物车详情)。
    • 传统单体应用,无需考虑跨域和分布式部署。
  2. 优先使用 Token(如 JWT)的场景

    • 前后端分离应用、API 接口认证。
    • 分布式系统或微服务架构(避免会话共享问题)。
    • 第三方授权(如 OAuth 2.0)。
  3. 混合使用场景

    • 用 Cookie 存储 Token(配合 HttpOnly 防止 XSS 攻击),同时利用 Token 的无状态特性。
    • 使用 Session 存储临时数据(如验证码),Token 用于长期身份验证。

五、安全注意事项

  1. Cookie 安全

    • 设置 HttpOnly:禁止 JavaScript 读取 Cookie,防范 XSS 攻击。
    • 设置 Secure:仅通过 HTTPS 传输 Cookie,防止中间人攻击。
    • 避免存储敏感数据(如密码)。
  2. Session 安全

    • 定期更新 sessionId(如用户重新登录时),防止会话固定攻击。
    • 限制 Session 存储时间,避免会话长期有效。
  3. Token 安全

    • 使用 HTTPS 传输 Token,防止明文泄露。
    • 对 JWT 签名(非对称加密,如 RS256),防止伪造。
    • 短时效 Token + 长时效刷新令牌(Refresh Token),降低 Token 泄露风险。

总结

  • Cookie 是客户端存储的基础,常与 Session 配合实现有状态会话管理。
  • Token 是无状态的身份凭证,适合现代分布式架构和 API 场景。
  • 选择时需结合业务需求(如是否跨域、数据量、安全性)和技术架构(单体 vs 微服务),避免过度设计或安全漏洞。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2384046.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

01-jenkins学习之旅-window-下载-安装-安装后设置向导

1 jenkins简介 百度百科介绍&#xff1a;Jenkins是一个开源软件项目&#xff0c;是基于Java开发的一种持续集成工具&#xff0c;用于监控持续重复的工作&#xff0c;旨在提供一个开放易用的软件平台&#xff0c;使软件项目可以进行持续集成。 [1] Jenkins官网地址 翻译&…

免费开放试乘体验!苏州金龙自动驾驶巴士即将上线阳澄数谷

近日&#xff0c;苏州自动驾驶巴士线路——阳澄数谷示范线正式上线&#xff0c;即日起向全民免费开放试乘体验&#xff01; 在苏州工业园区地铁3号线倪浜•阳澄数谷站外&#xff0c;一辆辆黑、白配色的小巴正在道路上有条不紊地行驶。与普通公交不同的是&#xff0c;小巴造型奇…

每日Prompt:像素风格插画

提示词 像素风格插画&#xff0c;日式漫画脸&#xff0c;画面主体为一位站在路边的男孩&#xff0c;人物穿着黑色冲锋衣&#xff0c;手里拿着手机&#xff0c;男孩靠坐在机车旁边&#xff0c;脚边依偎着一只带着小摩托车头盔的小小猫&#xff0c;背景是雨中&#xff0c;身旁停…

Windows逆向工程提升之二进制分析工具:HEX查看与对比技术

公开视频 -> 链接点击跳转公开课程博客首页 -> ​​​链接点击跳转博客主页 目录 十六进制查看工具 应用于逆向工程的知识点 ​编辑 二进制对比工具 应用于逆向工程的知识点 十六进制查看工具 十六进制查看器是逆向工程的基础工具&#xff0c;它可以以十六进制格式…

2024游戏安全白皮书:对抗激烈!PC游戏外挂功能数增长超149%,超85%移动外挂为定制挂(附获取方式)

2024 年&#xff0c;中国游戏市场实际销售收入达 3257.83 亿元&#xff0c;同比增长 7.53%&#xff1b;用户规模 6.74 亿人&#xff0c;同比增长 0.94%&#xff0c;再创新高。这份庞大的数据背后&#xff0c;更是对安全防线实力的严峻拷问。 在广东省游戏产业协会的指导下&…

12kV 环保气体绝缘交流金属封闭开关设备现场交流耐压试验规范

范围 本文件规定了12kV环保气体绝缘交流金属封闭开关设备现场交流耐压试验的被试设备及试验接线、试验条件、试验步骤、试验判据及异常处理方法。 本文件适用于12kV环保气体绝缘交流金属封闭开关设备现场交流耐压试验&#xff0c;其他气体绝缘交流金属封闭开关设备可参照执行。…

位图算法——判断唯一字符

这道题有多种解法&#xff0c;可以创建hash数组建立映射关系判断&#xff0c;但不用新的数据结构会加分&#xff0c;因此我们有“加分”办法——用位图。 我们可以创建一个整型变量&#xff08;32位&#xff09;而一共才26个字母&#xff0c;所以我们只要用到0-25位即可&#…

【UE5】环形菜单教程

效果 步骤 1. 下载图片资源&#xff1a;百度网盘 请输入提取码 提取码:fjjx 2. 将图片资源导入工程&#xff0c;如下 3. 新建3个控件蓝图&#xff0c;这里分别命名为“WBP_CircularMenu”、“WBP_Highlight”、“WBP_Icon” 4. 打开“WBP_Icon”&#xff0c;设置“所需” 添加…

Athena 执行引擎:在线服务计算的效率王者

引言 在在线服务领域&#xff0c;计算任务呈现出独特的特性&#xff1a;一方面&#xff0c;数据量通常不会过于庞大&#xff0c;因为在线服务对耗时和响应速度有着严苛要求&#xff1b;另一方面&#xff0c;计算任务具有可控性&#xff0c;其大多并非由用户实时输入动态生成&a…

飞桨paddle ‘ParallelEnv‘ object has no attribute ‘_device_id‘【已解决】

书借上回&#xff0c;自从我反复重装paddle之后&#xff0c;我发现了&#xff0c;只要pip list中有库&#xff0c;但是代码报错&#xff0c;那就是飞桨没把代码更新完全&#xff0c;只能自己去改源代码 我又遇到报错了&#xff1a; 根据报错信息&#xff0c;找到ParallelEnv报…

微信小程序之Promise-Promise初始用

我们来尝试使用Promise。 1、需求&#xff0c;做个抽奖的按钮&#xff0c; 抽奖规则&#xff1a; 30%的几率中奖&#xff0c;中奖会提示恭喜恭喜&#xff0c;奖品为10万 RMB 劳斯莱斯优惠券&#xff0c;没中奖会提示再接再厉。 2、先搭界面&#xff1a; <view class&qu…

准备好,开始构建:由 Elasticsearch 向量数据库驱动的 Red Hat OpenShift AI 应用程序

作者&#xff1a;来自 Elastic Tom Potoma Elasticsearch 向量数据库现在被 “基于 LLM 和 RAG 的 AI 生成” 验证模式支持。本文将指导你如何开始使用。 Elasticsearch 已原生集成业内领先的生成式 AI 工具和服务提供商。欢迎观看我们的网络研讨会&#xff0c;了解如何突破 RA…

RNN神经网络

RNN神经网络 1-核心知识 1-解释RNN神经网络2-RNN和传统的神经网络有什么区别&#xff1f;3-RNN和LSTM有什么区别&#xff1f;4-transformer的归一化有哪几种实现方式 2-知识问答 1-解释RNN神经网络 Why&#xff1a;与我何干&#xff1f; 在我们的生活中&#xff0c;很多事情…

Linux | 开机自启动设置多场景实现

注&#xff1a;本文为“Llinux 设置开机自启”相关文章合辑。 略作重排&#xff0c;未整理去重。 如有内容异常&#xff0c;请看原文。 Linux 设置开机自启动的三种方法 幽夜卡尔 2022-10-22 一、在 /etc/rc.local 文件中添加自启动命令 编辑文件&#xff1a;执行以下命令&a…

杨校老师竞赛课之青科赛GOC3-4年级组模拟题

1.山峰&#xff08;程序填空&#xff09;程序填空题 题目描述 编程画出山峰。 要求&#xff1a;两个正三角形&#xff0c;三角形边长分别是200、100&#xff0c;山峰的颜色为8号色。 int main() {// 绘制等边三角形&#xff08;边长100&#xff09;&#xff1a;右转30度调整…

SC3000智能相机-自动存图

1、需求:SC3000智能相机开机自动存图。相机自带的相机存储空间有限,预留存图需要开启SCMVS、并手动点存图。如果工人忘了开启则不会存图,导致生产严重失误! 2、方法:利用相机提供的FTP协议,将图自动存到本地。 1、在本地建立FTP服务器。 (1)win10默认开启了FTP服务器…

【Java高阶面经:微服务篇】5.限流实战:高并发系统流量治理全攻略

一、限流阈值的三维度计算模型 1.1 系统容量基准线:压测驱动的安全水位 1.1.1 压力测试方法论 测试目标:确定系统在资源安全水位(CPU≤80%,内存≤70%,RT≤500ms)下的最大处理能力测试工具: 单机压测:JMeter(模拟10万并发)、wrk(低资源消耗)集群压测:LoadRunner …

2025中青杯数学建模B题思路+模型+代码

本文将为大家带来2025年中青杯的选题建议&#xff0c;旨在十分钟内帮助大家快速了解每个题目具体难点、涉及模型等。初步预估赛题难度 A:B:C4:5:3初步预测选题人数 A:B:C2:1:0.6 首先是C题&#xff0c;忧郁症的双重防线&#xff1a;精准预测与有效治疗&#xff0c;这个题目涉及…

记录:uniapp 上线部署到微信小程序vendorjs包过大的问题

问题&#xff1a; 在代码依赖分析图中&#xff0c;可以看到主包的容量已经超过了2M了&#xff0c;分包没有超&#xff01; 根据网上的资料的解决方案&#xff0c;当前我已经做了以下相关的配置&#xff1a; 1.分包 2.在manifest.json的&#xff08;mp-weixin&#xff09;节点…

asp.net core 添加 EntityFrame

1&#xff1a;Nuget 引入程序集 Microsoft.EntityFrameworkCore Microsoft.EntityFrameworkCore.SqlServer Microsoft.EntityFrameworkCore.SqlServer.Design Microsoft.EntityFrameworkCore.Tools 2&#xff1a;执行脚本 Scaffold-DbContext "Data Source.;Initial Ca…