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

【Web安全】JWT常见安全漏洞总结

文章目录前言1. JWT基础与漏洞概述2. JWT核心漏洞解析2.1 未校验签名2.1.1 漏洞原理2.1.2 利用方式2.1.3 实战脚本2.2 算法篡改漏洞2.2.1 漏洞原理2.2.2 核心说明2.2.3 攻击流程2.3 弱密钥漏洞2.3.1 漏洞原理2.3.2 利用方式2.4 垂直越权2.4.1 漏洞原理2.4.2 利用流程2.5 KID字段注入2.5.1 触发条件2.5.2 四类利用方式3. 漏洞防御建议4. 总结⚠️本博文所涉安全渗透测试技术、方法及案例仅用于网络安全技术研究与合规性交流旨在提升读者的安全防护意识与技术能力。任何个人或组织在使用相关内容前必须获得目标网络 / 系统所有者的明确且书面授权严禁用于未经授权的网络探测、漏洞利用、数据获取等非法行为。前言在当今的Web开发中JSON Web TokenJWT作为身份认证与授权的常用凭证广泛应用于前后端分离、微服务等架构。然而由于服务端配置不当、算法使用不规范等原因JWT容易出现多种漏洞被攻击者利用来实现越权访问或伪造身份。1. JWT基础与漏洞概述JWT由Header头部、Payload载荷、Signature签名三部分构成主要用于实现无状态的身份验证。正常情况下服务端通过校验签名来确认JWT的完整性与合法性。但如果校验逻辑存在缺陷攻击者就能够通过篡改凭证、破解密钥等手段绕过认证获取未授权的访问权限。2. JWT核心漏洞解析2.1 未校验签名2.1.1 漏洞原理服务端存在两种致命缺陷一是完全不校验JWT的签名部分直接信任Payload中的内容二是允许使用alg: none无签名算法该算法规定JWT无需进行签名校验仅需保证格式正确即可通过验证。这两种情况均允许攻击者任意篡改Payload中的用户ID、权限等核心信息实现身份伪造。2.1.2 利用方式修改JWT头部Header将算法指定为none即alg: none篡改Payload中的关键字段如将普通用户IDsub: 10086改为管理员IDsub: 1调整过期时间exp延长凭证有效期清除签名部分JWT最后一个.后面的内容留空提交篡改后的JWT即可绕过认证。2.1.3 实战脚本以下Python脚本可直接构造None算法的恶意JWT可根据目标系统调整Payload字段importtimeimportjwtdefforge_jwt_none_attack(exp_offset3600): 构造 JWT None 算法攻击的 Token :param exp_offset: 过期时间偏移秒默认1小时 :return: 构造好的 JWT Token header{typ:JWT,alg:none}# Payloadnowint(time.time())payload{exp:nowexp_offset,# 过期时间iat:now,# 签发时间iss:echisan,sub:业务参数,}# 生成 JWTkeyNone, algorithmNonetry:jwt_tokenjwt.encode(payload,keyNone,algorithmNone,headersheader)exceptTypeError:jwt_tokenjwt.encode(payload,key,# 部分旧版本需要传空字符串algorithmnone,headersheader)# 处理编码ifisinstance(jwt_token,bytes):jwt_tokenjwt_token.decode(utf-8)returnjwt_tokenif__name____main__:forged_tokenforge_jwt_none_attack()print(forged_token)2.2 算法篡改漏洞2.2.1 漏洞原理正常业务使用RS256非对称算法签名服务器持有私钥进行签名并对外公开公钥用于验签。该漏洞的根源在于服务端不硬编码指定验签算法而是直接读取JWT头部的alg字段来动态选择验签方式。攻击者将头部的alg:RS256篡改为alg:HS256然后利用服务器公开的RSA公钥直接作为HS256的对称密钥自行完成签名伪造。服务端读取alg为HS256后会误用公钥当作对称密钥完成验签从而直接放行恶意Token。2.2.2 核心说明服务器拥有私钥为何不用私钥验签RS256规范规定只能用公钥验签私钥仅负责签名验签流程全程不会使用私钥这是协议的固有规则。为何会用公钥当做HS256密钥这是由于程序逻辑存在缺陷只判断alg字段不设置算法白名单进行拦截。当切换为HS256对称验签后直接复用原有传入的公钥作为对称密钥导致验签失效。2.2.3 攻击流程抓取正常业务JWT获取服务器对外暴露的RSA公钥修改Header内alg值由RS256改为HS256篡改Payload内用户ID、权限、角色等敏感字段使用服务器公钥作为HS256密钥重新生成签名携带伪造Token请求接口服务端成功验签通过实现身份伪造。2.3 弱密钥漏洞2.3.1 漏洞原理JWT使用对称加密算法如HS256时服务端会使用固定密钥对JWT进行签名与校验。若该密钥强度极低攻击者可通过暴力破解的方式获取密钥进而伪造任意合法JWT。2.3.2 利用方式核心是通过工具爆破弱密钥常用工具推荐TscanPlusTideSec开源工具集成JWT弱密钥破解功能支持自定义字典操作便捷可直接联动其他功能进行后续攻击破解密钥后即可使用该密钥签名任意篡改后的Payload生成合法JWT。2.4 垂直越权2.4.1 漏洞原理垂直越权并非JWT自身的算法漏洞而是基于上述两种漏洞未校验签名、弱密钥的衍生攻击。攻击者通过伪造高权限用户的JWT凭证绕过服务端的权限控制访问原本只有管理员等高级角色才能访问的接口或资源。2.4.2 利用流程通过无签名攻击或弱密钥爆破获取伪造高权限JWT的能力篡改Payload中的权限字段如role: admin生成高权限JWT携带该JWT请求高权限接口如/admin/user/list、/system/setting实现垂直越权访问。2.5 KID字段注入2.5.1 触发条件JWT头部的kidKey ID字段用于指定服务端校验签名时使用的密钥如密钥文件路径、数据库中的密钥ID。若服务端未对kid字段进行过滤直接将其拼接至密钥读取、查询逻辑中攻击者可通过注入恶意内容实现SQL注入、命令执行、文件读取等攻击。2.5.2 四类利用方式SQL注入核心思路通过kid字段注入SQL语句篡改密钥查询结果让服务端使用攻击者指定的密钥进行签名校验。示例注入语句xxx_key UNION selectmykey from INFORMATION_SCHEMA.SYSTEM_USERS --关键注意点xxx_key必须是不存在的密钥确保UNION查询生效mykey为攻击者指定的密钥可根据需求进行Base64编码增强隐蔽性。此外还可结合布尔盲注、时间盲注获取服务端数据库中的真实密钥。命令注入适用场景服务端使用Ruby等语言通过open函数读取密钥文件时kid字段可拼接命令。测试方式在kid字段中注入命令拼接内容如kid: key|whoami若服务端执行该命令可获取服务器权限。该场景较为少见主要出现在配置不规范的Ruby项目中。文件读取路径穿越读取密钥通过kid字段注入路径穿越字符读取服务端本地的密钥文件如kid: ../../../../../etc/passwd读取系统用户信息、kid: ../../../../../var/www/secret.key读取应用密钥文件空密钥利用注入kid: ../../../../../dev/null让服务端读取空文件作为密钥此时可使用空密钥签名JWT实现伪造。3. 漏洞防御建议针对上述漏洞从开发与运维角度给出以下防御措施避免JWT被滥用严格校验签名禁止使用alg: none算法服务端必须校验JWT的签名完整性不信任未签名或签名无效的凭证明确指定验签算法避免动态读取alg字段导致算法篡改漏洞。强化密钥安全使用对称加密算法时采用高强度密钥至少16位随机字符串定期更换密钥优先使用非对称加密算法如RS256私钥严格保管不对外泄露。过滤危险字段对JWT头部的kid等字段进行严格过滤禁止特殊字符如、、|、../避免注入攻击。限制Payload权限Payload中不存储敏感信息如密码、密钥权限字段如role需在服务端二次校验不依赖JWT中的内容。缩短凭证有效期合理设置JWT的exp过期时间建议不超过1小时降低凭证泄露后的风险。4. 总结JWT漏洞的产生主要源于服务端校验逻辑不严谨、配置不当。攻击者利用篡改凭证、破解密钥、注入攻击等手段绕过身份认证与权限控制。对于安全从业者可借助本文内容快速识别JWT漏洞开展渗透测试。后续可结合具体项目场景深入研究JWT的进阶攻击方式进一步提升安全防护能力。本文是「Web安全基础」系列内容点击专栏导航查看全部系列内容。

相关文章:

【Web安全】JWT常见安全漏洞总结

文章目录前言1. JWT基础与漏洞概述2. JWT核心漏洞解析2.1 未校验签名2.1.1 漏洞原理2.1.2 利用方式2.1.3 实战脚本2.2 算法篡改漏洞2.2.1 漏洞原理2.2.2 核心说明2.2.3 攻击流程2.3 弱密钥漏洞2.3.1 漏洞原理2.3.2 利用方式2.4 垂直越权2.4.1 漏洞原理2.4.2 利用流程2.5 KID字段…...

从一次线上故障复盘:如何用 nlohmann::json 的 `value()` 和 `get_to()` 优雅处理缺失字段

从一次线上故障复盘:如何用 nlohmann::json 的 value() 和 get_to() 优雅处理缺失字段 上周五晚上10点,我们的算法服务平台突然收到大量错误告警。一个核心接口在解析上传的算法包时频繁报错,日志里满是[json.exception.type_error.302] type…...

告别手写轮播!用vue-j-scroll插件5分钟搞定Vue列表无缝滚动(含鼠标悬停控制)

5分钟极速集成:用vue-j-scroll实现Vue列表智能滚动方案 在数据密集型的现代Web应用中,动态列表展示几乎成为标配需求。无论是后台管理系统的操作日志、金融平台的实时交易流水,还是新闻客户端的资讯推送,流畅的自动滚动效果不仅能…...

从一次数据解析Bug说起:彻底搞懂QString的toLocal8Bit、toUtf8和toLatin1该用哪个

从一次数据解析Bug说起:彻底搞懂QString的编码转换选择 上周排查一个网络协议解析问题时,遇到一个典型的编码陷阱:服务端返回的GBK编码数据包,在Qt客户端用toUtf8()解析后出现乱码。这个看似简单的编码问题背后,隐藏着…...

RANSAC算法:从理论到实战,解锁三维点云中的平面拟合

1. RANSAC算法:三维点云中的"找茬大师" 第一次接触三维点云数据时,我被那些密密麻麻的空间点震撼到了——就像在显微镜下看一群乱飞的萤火虫。但当导师让我从这些点里找出墙面和地面时,我彻底懵了。直到遇到RANSAC算法,…...

8051单片机sbit位操作失效问题与volatile解决方案

1. 问题现象与背景解析在8051单片机开发中,我们经常需要对寄存器或内存中的特定位进行操作。Keil C51编译器提供了sbit关键字来实现位寻址功能,这是一种非常高效的位操作方式。但在实际开发中,不少工程师遇到过这样的困扰:明明在代…...

C#从零开始学习笔记---第七天

不是同样的时间,不是同样的笔记,但是同样的作者。新的一天,欢迎收看我的学习笔记吼吼~我们昨天最后留了两道题,不知道大家做的怎么样,我现在来公布一下答案,但因为1000个人心里有1000个哈姆雷特&#xff0c…...

量子同态加密:理论与实践的突破

1. 量子同态加密:理论与实践的桥梁量子同态加密(Quantum Homomorphic Encryption, QHE)是密码学领域的一项突破性技术,它允许在加密的量子数据上直接执行任意量子计算,而无需事先解密。这项技术对于构建真正隐私保护的…...

一款支持USB2.0的4端口集线器芯片

GM8220C是成都振芯科技推出的一款支持USB2.0的4端口集线器芯片。它充分满足USB2.0和充电协议(BC1.1/1.2),具备多种工作模式和充电支持功能,适用于多种设备。1. 主要特征协议兼容:兼容USB2.0协议,并向下兼容…...

CanMV K230 家用电器电流识别 预告

数据采集:家用电器电流采集 数据分析:电流波形与特征 识别方法: 硬件设置: 算法部署: 电器可能包括:手机充电器、电脑、电视、热水壶等...

Perplexity引用格式设置全链路解析(含BibTeX/CSL/DOI自动映射底层逻辑)

更多请点击: https://kaifayun.com 第一章:Perplexity引用格式设置全链路解析(含BibTeX/CSL/DOI自动映射底层逻辑) Perplexity 在学术写作支持中并非原生集成引文管理,但其底层可对接外部文献元数据服务,实…...

ARM9老开发板救星:用BusyBox 1.7.0和4.3.2工具链构建根文件系统(避坑实录)

ARM9开发板重生指南:BusyBox 1.7.0与4.3.2工具链的黄金组合 当一块尘封多年的ARM9开发板重新出现在你面前,那种感觉就像考古学家发现了一件珍贵的文物。S3C2440这类老将虽然性能比不上现代Cortex-A系列,但在教学、工业控制等领域依然有不可替…...

A-59F所有应用模式说明

A-59F 是一款高集成语音处理模组,一体化实现 AI ENC 降噪、AEC 回音消除、扩音防啸叫、BF 波束拾音 四大核心能力。支持模拟 / 数字麦克风、模拟 / I2S 数字音频接口,邮票孔 SMT 封装,体积小巧、易嵌入,可大幅简化音频电路&#x…...

【网络安全】2026最新网安渗透测试标准及流程!新手小白零基础入门必看教程!

✅一、了解渗透测试 🔴什么是渗透测试? 渗透测试是一种安全性测试,通过发起模拟网络攻击的方式查找计算机系统中的漏洞。 渗透测试人员是拥有高超道德黑客技术的安全专业人员(道德黑客是指运用黑客工具和黑客技术来修复安全薄弱环…...

影刀RPA工程实战:多店铺环境隔离体系与自动化流程的事务性保障

一个店铺登录态串到另一个店铺,只在一瞬间。 但要真正杜绝它,需要的是一整套工程约束。 上一篇文章聊了浏览器实例池与并发调度,那套东西帮我们扛住了几十个店铺同时跑的稳定性。但很快我们又遇到了一个新问题:店铺之间的环境边界…...

自动售货机哪个品牌好?2026年选购避坑全攻略~YH

经常有朋友问我:“自动售货机到底选哪个牌子?”说实话,这个问题我之前也纠结过。市面上做自动售货机的品牌不下几十家,价格从几千到几万都有,广告一个比一个响。但真正用下来,才知道差别有多大。今天就把这…...

生态学家都在用的R包MixSIAR:手把手教你用贝叶斯模型搞定食物网溯源

生态数据分析实战:用MixSIAR实现贝叶斯食物网溯源 河口湿地的鱼类究竟以藻类还是陆源有机物为主要食物?这个看似简单的问题背后,隐藏着复杂的生态关系网络。传统稳定同位素分析方法虽然能提供部分答案,但当面对多个潜在食物源和不…...

压接 vs 焊接:高速连接器组装工艺的选型指南与实战对比

摘要/前言在通信设备、工业控制及数据中心硬件设计中,连接器的组装工艺选择直接影响产品的可靠性、可维护性与生产良率。压接(Press-Fit)与焊接(Soldering)是当前通孔连接器最主要的两种电气互连方式。压接依靠过盈配合…...

关键字[Static]

一、static 的三种用法 1. 静态局部变量 * 特性: * - 只初始化一次(程序启动时) * - 函数返回后值保留(不销毁) * - 下次调用时保持上次的值 * - 存储在静态区,不在栈上 2. 静态全局变量(文件作用域限制) 仅在 xx.c 内可见,其他文件无法访问 3. 静态函数(文件作用域限…...

遗传算法组卷效果总是不理想?可能是你的‘适应度函数’没调好(Java实战避坑)

遗传算法组卷效果优化:从适应度函数设计到Java实战调优 当你在深夜盯着屏幕,反复运行遗传算法组卷程序却始终得不到理想的试卷时,那种挫败感我深有体会。三年前我在开发在线教育平台时,曾连续两周被组卷效果不稳定问题困扰——试卷…...

SteamAutoCrack终极破解指南:三分钟移除游戏DRM保护

SteamAutoCrack终极破解指南:三分钟移除游戏DRM保护 【免费下载链接】Steam-auto-crack Steam Game Automatic Cracker 项目地址: https://gitcode.com/gh_mirrors/st/Steam-auto-crack 你是否遇到过Steam游戏无法离线运行的问题?或者想要在没有S…...

告别PCL!用Qt+QGLWidget手把手教你打造自己的3D点云查看器(附完整源码)

轻量级3D点云可视化:基于Qt与OpenGL的高效实现方案 在工业测量、自动驾驶和三维重建等领域,点云数据的可视化一直是开发者面临的挑战。传统方案如PCL虽然功能强大,但其庞大的体积和复杂的依赖链往往让项目变得臃肿。本文将展示如何利用Qt的QG…...

系统架构设计师-2025年05月综合案例回忆版

试题 试题一(必选题) 某公司开发一个在线大模型训练平台,支持Python代码编写、模型训练和部署,用户通过python编写模型代码,将代码交给系统进行模型代码的解析,最终由系统匹配相应的计算机资源进行输出,用户不需要关心底层硬件平台,在开发该平台架构时,设计了以下质…...

餐饮行业使用的企业管理软件

你是否遇到过门店食材库存数与实际不符,月底盘点要通宵?或者多门店营收数据混乱,财务结账要花半个月?据中国烹饪协会数据,68%的中大型餐饮企业因管理软件适配性差,每年额外损耗10%-15%的食材成本。今天这篇…...

别再死记硬背了!用Python+Simulink仿真液压系统,帮你彻底搞懂帕斯卡原理和伯努利方程

用Python和Simulink仿真液压系统:从理论到实践的沉浸式学习 液压传动作为现代机械工程的核心技术之一,其理论基础往往让初学者望而生畏。帕斯卡原理、伯努利方程这些看似简单的公式背后,隐藏着复杂的物理现象和工程应用。传统的死记硬背方式不…...

CuteTranslation:Linux系统上的专业级屏幕取词翻译解决方案

CuteTranslation:Linux系统上的专业级屏幕取词翻译解决方案 【免费下载链接】CuteTranslation Linux屏幕取词翻译软件 项目地址: https://gitcode.com/gh_mirrors/cu/CuteTranslation CuteTranslation是一款基于Qt框架和X11系统开发的Linux屏幕取词翻译软件&…...

潍坊漆面车衣怎么选才合适?

很多潍坊车主在给爱车选漆面保护膜时,都会有这样的困惑:网上信息真假难辨,线下门店推荐又参差不齐,到底该怎么选才合适?其实,选漆面车衣没有想象中那么复杂,关键是要掌握一套通用的判断标准。本…...

记一次 mac openClaw gateway 启动未正常关闭导致的问题

openclaw 目前是一个比较火的 AI 工具,因为其高权限带来了一系列的风险和安全隐患按照官方步骤删除后,因open claw 的 gateway 没有正常关闭,导致端口一直在后台运行如果您也遇到类似的问题,可在 mac 终端执行如下命令进行关闭1.先…...

企业视频会议系统从公有云迁移到私有化环境:完整数据迁移指南

摘要:企业从Zoom、腾讯会议等公有云SaaS视频会议系统迁移到私有化部署的会议平台时,需要处理用户数据、历史会议记录、录制文件等关键资产的平滑过渡。本文提供一套经过生产验证的迁移方案,涵盖数据导出、批量导入、API对接、录制文件转存及验…...

企业级融媒体生产管理平台/智能会议管理系统EasyDSS构建一体化应急视频指挥体系

在自然灾害、安全生产事故等突发事件处置中,应急指挥的核心诉求是数据绝对安全、指令极速传递、态势全面感知。私有化视频会议系统EasyDSS打破传统协作壁垒,为应急指挥打造专属化、高可靠的音视频中枢,成为应急处置的核心技术支撑。一、私有化…...