PHP手动解析JWT令牌教程
PHP中手动解析JWT令牌绝非简单调用JWT::decode()即可完成——该方法仅负责解码与基础解析,完全不校验签名有效性、算法合规性及时间字段(如exp、nbf),若忽略显式传入密钥$key、严格限定$allowed_algs数组并手动验证过期与生效时间,将导致严重安全漏洞:攻击者可轻松伪造管理员权限token、绕过签名检查、滥用已过期凭证;尤其在v6.4+版本中,$allowed_algs已成为不可省略的强制参数,且RS256等非对称算法还需正确加载PEM公钥资源,任何一步疏漏都可能让系统“裸奔”于未授权访问风险之中。

PHP中用 firebase/php-jwt 手动验证JWT签名是否有效
直接说结论:不能只调用 JWT::decode() 就算完事,它默认不校验签名,也不检查过期时间,必须显式传入 $key 和 $allowed_algs,否则等于裸奔。
常见错误现象是:伪造的 token(比如把 payload 改成 {"admin":true} 后重签一个无效签名)也能 decode 成功,只是返回数组而已——因为没校验签名,decode() 本质只是 base64url 解码 + JSON 解析。
- 必须传入真实密钥(
$key),且类型匹配:HS256 用字符串,RS256 用 PEM 公钥资源或字符串 - 必须指定
$allowed_algs数组,比如['HS256'],否则会跳过算法校验(CVE-2015-2951 类风险) - 过期(
exp)、生效时间(nbf)、签发者(iss)等都得自己检查,decode()不自动做
JWT::decode() 报错 DomainException: Algorithm not allowed
这是最常卡住人的点:不是密钥错了,而是没传 $allowed_algs 参数,或者传了但内容不匹配 header 中的 alg 字段。
比如 token header 是 {"alg":"HS256"},但你写的是 ['RS256'],就会报这个错;更隐蔽的是漏传该参数——函数签名里它是第 3 个必填参数(v6+),旧版 v5 可能容忍空数组,但行为不可靠。
- v6.4+ 版本中,
JWT::decode($jwt, $key, $allowed_algs)第三个参数不可省略 - 别用
['none']或空数组绕过,那等于关掉签名校验 - 如果 token 来自不同服务混用多种算法(极不推荐),才考虑传
['HS256', 'RS256'],但务必确保密钥类型和算法严格对应
手动验证 exp、nbf 等时间字段的必要性
JWT::decode() 返回的是原始 payload 数组,它不会主动抛异常或过滤过期 token。你拿到 $decoded->exp 是个 Unix 时间戳,但 PHP 不会自动比对 time()。
典型翻车场景:用户登出后 token 没进黑名单,又没检查 exp,结果过期 token 还能访问敏感接口。
- 必须手动判断:
if (isset($decoded->exp) && $decoded->exp nbf(not before)同理,$decoded->nbf > time()就该拒绝- 注意时区:所有时间戳都是 UTC,别用
date('U')以外的方式生成或比较
用 openssl_pkey_get_public() 加载 RS256 公钥的坑
如果你用 RSA 签名(比如 Auth0、AWS Cognito),$key 参数不能直接传 PEM 字符串,得先转成资源,否则 decode() 会静默失败或报错 Signature verification failed。
错误写法:JWT::decode($token, "-----BEGIN PUBLIC KEY-----...", ['RS256']) —— 这在 v6+ 会直接抛异常。
- 正确做法:用
$pubKey = openssl_pkey_get_public($pemString),再传$pubKey给decode() - 记得检查返回值:
if (!$pubKey) { throw new Exception('Invalid public key'); } - PEM 字符串必须包含完整头尾(
-----BEGIN PUBLIC KEY-----),且换行符是 \n(Windows 下可能多 \r 导致加载失败)
decode() 不等于“验证”,它只是解码入口;真正的验证是密钥 + 算法 + 时间字段三者缺一不可的手动组合检查。今天关于《PHP手动解析JWT令牌教程》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!
JavaScript性能优化技巧与减少重复计算方法
- 上一篇
- JavaScript性能优化技巧与减少重复计算方法
- 下一篇
- JavaScript代码分割实用技巧分享
-
- 文章 · php教程 | 2天前 | 面向对象 · PHP · PHP8.4 · Property Hooks · 代码重构 · PHP教程 Getter PHP 8.4 Property Hooks setter
- PHP 8.4 Property Hooks 实战:把 getter/setter 收回到属性声明里
- 464浏览 收藏
-
- 文章 · php教程 | 1星期前 | WEB开发 · 登录状态 · Cookie · PHP · session · session_start · php cookie session session_start PHPSESSID 登录态丢失
- PHP Session 登录态突然丢失怎么办:从 Cookie 到 session_start 一步步排查
- 196浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ljg-skills
- ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。
- 2959次使用
-
- MELO音乐
- MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款!
- 2733次使用
-
- UniScribe
- UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。
- 2668次使用
-
- 剧云
- 剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。
- 2899次使用
-
- 万象有声
- 万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单!
- 2849次使用
-
- 宝塔配置Ruby环境:RVM+Nginx反代教程
- 2026-05-29 501浏览
-
- unset函数作用范围详解
- 2026-05-29 501浏览
-
- VS Code配置Xdebug教程:PHP调试技巧全解析
- 2026-05-13 501浏览
-
- PHPEnv安装PhpMyAdmin教程详解
- 2026-05-07 501浏览
-
- TelegramBotWebApp数据验证技巧
- 2026-05-06 501浏览

