JWT安全机制与最佳实践详解

JWT(JSON Web Token) 是一种开放标准(RFC 7519),用于在各方之间安全地传输信息作为紧凑且自包含的 JSON 对象。它被广泛用于身份验证(Authentication)和授权(Authorization),是现代 Web 开发中替代传统 Session-Cookie 方案的流行技术。


核心结构:三部分拼接

JWT 由三部分组成,用 . 分隔:
Header.Payload.Signature
示例:
eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0IiwibmFtZSI6IkpvaG4iLCJpYXQiOjE1MTYyMzkwMjJ9.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c

1. Header(头部)
  • 作用:声明令牌类型和签名算法。
  • 示例
    {"alg": "HS256",  // 签名算法(如 HS256、RS256)"typ": "JWT"     // 令牌类型
    }
    
  • Base64Url 编码 → 生成第一部分。
2. Payload(负载)
  • 作用:携带实际数据(如用户 ID、权限、过期时间)。
  • 包含三类声明
    • 预定义声明(Registered Claims):标准字段(非强制)
      iss(签发者)、exp(过期时间)、sub(主题)、aud(受众)等。
    • 公开声明(Public Claims):自定义公开字段(需避免冲突)。
    • 私有声明(Private Claims):双方约定的自定义数据。
  • 示例
    {"sub": "1234567890",      // 用户 ID"name": "Alice","admin": true,"iat": 1516239022         // 签发时间
    }
    
  • Base64Url 编码 → 生成第二部分。
3. Signature(签名)
  • 作用:验证令牌完整性和来源可信性。
  • 生成公式
    HMACSHA256(base64UrlEncode(header) + "." + base64UrlEncode(payload),secretKey
    )
    
  • 关键点
    • 使用 Header 指定的算法(如 HS256)和密钥生成。
    • 防篡改:任何对 Header 或 Payload 的修改都会导致签名验证失败。

工作流程:身份验证场景

客户端服务端提交用户名/密码验证凭证生成JWT并返回后续请求携带JWT(Header: Authorization: Bearer <token>)验证签名+检查有效期返回受保护资源客户端服务端

关键特性

特性说明
无状态(Stateless)服务端无需存储会话信息,减轻数据库压力。
跨域友好可放在 HTTP Header 或 URL 中,不受同源策略限制(与 Cookie 不同)。
自包含(Self-contained)Payload 可直接解析出用户信息,减少查询次数。
可扩展性自定义 Payload 添加业务数据(如用户角色、权限列表)。

安全注意事项

  1. 敏感信息泄露
    问题:Payload 仅 Base64 编码(非加密),可被解码查看。
    解决

    • 避免在 Payload 存储密码、银行卡号等敏感数据。
    • 敏感数据需加密后再放入 Payload。
  2. 签名算法安全

    • 禁用 "alg": "none":防止攻击者绕过签名验证。
    • 推荐强算法:如 HS256(对称)或 RS256(非对称)。
  3. 密钥管理

    • HS256:密钥需足够复杂(长度 >32 字符),并在服务端安全存储。
    • RS256:私钥严格保密,公钥用于验证(更安全)。
  4. 令牌过期

    • 必设 exp(过期时间),缩短攻击窗口期(建议 15-30 分钟)。
  5. 令牌吊销问题
    难点:JWT 天然无状态,无法中途废止(除非等待过期)。
    解决方案

    • 维护令牌黑名单(需牺牲无状态性)。
    • 设置短有效期 + 使用 Refresh Token 机制(见下图)。

最佳实践:Access Token + Refresh Token

1. 登录请求
2. 返回 Access Token + Refresh Token
3. 用 Access Token 请求资源
4. Token 过期
5. 用 Refresh Token 申请新 Access Token
6. 验证后返回新 Access Token
客户端
服务端
API
  • Access Token:短有效期(如 15 分钟),用于请求资源。
  • Refresh Token:长有效期(如 7 天),存储于数据库,用于获取新 Access Token。

代码示例:Node.js 生成/验证 JWT

const jwt = require('jsonwebtoken');// 生成 JWT(HS256 对称算法)
const payload = { userId: "123", role: "admin" };
const secret = "your-strong-secret"; // 密钥
const token = jwt.sign(payload, secret, { expiresIn: '1h' });
console.log("Generated Token:", token);// 验证 JWT
jwt.verify(token, secret, (err, decoded) => {if (err) console.error("验证失败:", err.message);else console.log("Decoded Payload:", decoded); // { userId: '123', role: 'admin', iat: ..., exp: ... }
});

适用场景 vs 不适用场景

适用场景不适用场景
无状态 API 认证需要即时吊销令牌的系统
微服务间安全通信传输大量敏感数据
单点登录(SSO)客户端无法安全存储令牌的场景
移动端/前后端分离应用

调试工具

  • 在线解析:https://jwt.io
    (可查看 Header/Payload,但勿泄露真实 Token)

总结

  • JWT 本质Base64(Header).Base64(Payload).Signature
  • 核心价值:无状态、跨域友好、自包含。
  • 安全铁律:强签名算法、短有效期、避免敏感数据、密钥严格保护。
  • 进阶方案:Access Token + Refresh Token 平衡安全性与用户体验。

理解 JWT 的机制和安全实践,是构建现代分布式系统的必备技能。

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

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

相关文章

如何解决pip安装报错ModuleNotFoundError: No module named ‘ipython’问题

【Python系列Bug修复PyCharm控制台pip install报错】如何解决pip安装报错ModuleNotFoundError: No module named ‘ipython’问题 摘要 在开发过程中&#xff0c;我们常常会遇到pip install报错的问题&#xff0c;其中一个常见的报错是 ModuleNotFoundError: No module named…

从三维Coulomb势到二维对数势的下降法推导

题目 问题 7. 应用 9.1.4 小节描述的下降法&#xff0c;但针对二维的拉普拉斯方程&#xff0c;并从三维的 Coulomb 势出发 KaTeX parse error: Invalid delimiter: {"type":"ordgroup","mode":"math","loc":{"lexer&qu…

直播一体机技术方案解析:基于RK3588S的硬件架构特性​

硬件配置​​主控平台​​▸ 搭载瑞芯微RK3588S旗舰处理器&#xff08;四核A762.4GHz 四核A55&#xff09;▸ 集成ARM Mali-G610 MP4 GPU 6TOPS算力NPU▸ 双通道LPDDR5内存 UFS3.1存储组合​​专用加速单元​​→ 板载视频采集模块&#xff1a;支持4K60fps HDMI环出采集→ 集…

【氮化镓】GaN取代GaAs作为空间激光无线能量传输光伏转换器材料

2025年7月1日,西班牙圣地亚哥-德孔波斯特拉大学的Javier F. Lozano等人在《Optics and Laser Technology》期刊发表了题为《Gallium nitride: a strong candidate to replace GaAs as base material for optical photovoltaic converters in space exploration》的文章,基于T…

直播美颜SDK动态贴纸模块开发指南:从人脸关键点识别到3D贴合

很多美颜技术开发者好奇&#xff0c;如何在直播美颜SDK中实现一个高质量的动态贴纸模块&#xff1f;这不是简单地“贴图贴脸”&#xff0c;而是一个融合人脸关键点识别、实时渲染、贴纸驱动逻辑、3D骨骼动画与跨平台性能优化的系统工程。今天&#xff0c;就让我们从底层技术出发…

学习游戏制作记录(剑投掷技能)7.26

1.实现瞄准状态和接剑状态准备好瞄准动画&#xff0c;投掷动画和接剑动画&#xff0c;并设置参数AimSword和CatchSword投掷动画在瞄准动画后&#xff0c;瞄准结束后才能投掷创建PlayerAimSwordState脚本和PlayerCatchSwordState脚本并在Player中初始化&#xff1a;PlayerAimSwo…

【c++】问答系统代码改进解析:新增日志系统提升可维护性——关于我用AI编写了一个聊天机器人……(14)

在软件开发中&#xff0c;代码的迭代优化往往从提升可维护性、可追踪性入手。本文将详细解析新增的日志系统改进&#xff0c;以及这些改进如何提升系统的实用性和可调试性。一、代码整体背景代码实现了一个基于 TF-IDF 算法的问答系统&#xff0c;核心功能包括&#xff1a;加载…

visual studio2022编译unreal engine5.4.4源码

UE5系列文章目录 文章目录 UE5系列文章目录 前言 一、ue5官网 二.编译源码中遇到的问题 前言 一、ue5官网 UE5官网 UE5源码下载地址 这样虽然下载比较快,但是不能进行代码git管理,以后如何虚幻官方有大的版本变动需要重新下载源码,所以我们还是最好需要visual studio2022…

vulhub Earth靶场攻略

靶场下载 下载链接&#xff1a;https://download.vulnhub.com/theplanets/Earth.ova 靶场使用 将压缩包解压到一个文件夹中&#xff0c;右键&#xff0c;用虚拟机打开&#xff0c;就创建成功了&#xff0c;然后启动虚拟机&#xff1a; 这时候靶场已经启动了&#xff0c;咱们现…

Python训练Day24

浙大疏锦行 元组可迭代对象os模块

Spring核心:Bean生命周期、外部化配置与组件扫描深度解析

Bean生命周期 说明 程序中的每个对象都有生命周期&#xff0c;对象的创建、初始化、应用、销毁的整个过程称之为对象的生命周期&#xff1b; 在对象创建以后需要初始化&#xff0c;应用完成以后需要销毁时执行的一些方法&#xff0c;可以称之为是生命周期方法&#xff1b; 在sp…

日语学习-日语知识点小记-进阶-JLPT-真题训练-N1阶段(1):2017年12月-JLPT-N1

日语学习-日语知识点小记-进阶-JLPT-真题训练-N1阶段&#xff08;1&#xff09;&#xff1a;2017年12月-JLPT-N1 1、前言&#xff08;1&#xff09;情况说明&#xff08;2&#xff09;工程师的信仰&#xff08;3&#xff09;真题训练2、真题-2017年12月-JLPT-N1&#xff08;1&a…

(一)使用 LangChain 从零开始构建 RAG 系统|RAG From Scratch

RAG 的主要动机 大模型训练的时候虽然使用了庞大的世界数据&#xff0c;但是并没有涵盖用户关心的所有数据&#xff0c; 其预训练令牌&#xff08;token&#xff09;数量虽大但相对这些数据仍有限。另外大模型输入的上下文窗口越来越大&#xff0c;从几千个token到几万个token,…

OpenCV学习探秘之一 :了解opencv技术及架构解析、数据结构与内存管理​等基础

​一、OpenCV概述与技术演进​ 1.1技术历史​ OpenCV&#xff08;Open Source Computer Vision Library&#xff09;是由Intel于1999年发起创建的开源计算机视觉库&#xff0c;后来交由OpenCV开源社区维护&#xff0c;旨在为计算机视觉应用提供通用基础设施。经历20余年发展&…

什么是JUC

摘要 Java并发工具包JUC是JDK5.0引入的重要并发编程工具&#xff0c;提供了更高级、灵活的并发控制机制。JUC包含锁与同步器&#xff08;如ReentrantLock、Semaphore等&#xff09;、线程安全队列&#xff08;BlockingQueue&#xff09;、原子变量&#xff08;AtomicInteger等…

零基础学后端-PHP语言(第二期-PHP基础语法)(通过php内置服务器运行php文件)

经过上期的配置&#xff0c;我们已经有了php的开发环境&#xff0c;编辑器我们继续使用VScode&#xff0c;如果是新来的朋友可以看这期文章来配置VScode 零基础学前端-传统前端开发&#xff08;第一期-开发软件介绍与本系列目标&#xff09;&#xff08;VScode安装教程&#x…

扩散模型逆向过程详解:如何从噪声中恢复数据?

在扩散模型中&#xff0c;逆向过程的目标是从噪声数据逐步恢复出原始数据。本文将详细解析逆向条件分布 q(zt−1∣zt,x)q(\mathbf{z}_{t-1} \mid \mathbf{z}_t, \mathbf{x})q(zt−1​∣zt​,x)的推导过程&#xff0c;揭示扩散模型如何通过高斯分布实现数据重建。1. 核心问题 在…

2025年7月份实时最新获取地图边界数据方法,省市区县街道多级联动【文末附实时geoJson数据下载】

动态生成最新行政区划 GeoJSON 数据并结合 ECharts 实现地图下钻功能 在开发基于地图的数据可视化应用时&#xff0c;一个常见的挑战是获取准确且最新的行政区划边界数据&#xff08;GeoJSON&#xff09;。许多现有的在线资源可能数据陈旧&#xff0c;无法反映最新的行政区划调…

Spark实现WorldCount执行流程图

spark可以分区并行执行&#xff0c;同时并行执行也可以基于内存完成迭代代码对于大部分spark程序来说都是以driver开始driver结束&#xff0c;中间都是executor分布式运行

编程与数学 03-002 计算机网络 02_网络体系结构与协议

编程与数学 03-002 计算机网络 02_网络体系结构与协议一、网络体系结构的基本概念&#xff08;一&#xff09;分层体系结构的优点&#xff08;二&#xff09;协议、接口与服务的概念二、OSI参考模型&#xff08;一&#xff09;七层模型的层次划分及功能&#xff08;二&#xff…