0

0

掌握 JWT(JSON Web 令牌):深入探讨

霞舞

霞舞

发布时间:2025-01-21 21:12:01

|

601人浏览过

|

来源于php中文网

原创

json web token (jwt)详解:跨域认证的流行解决方案

掌握 JWT(JSON Web 令牌):深入探讨

JWT是当前最广泛使用的跨域身份验证解决方案。本文将深入探讨其工作原理和使用方法。

一、跨域认证的挑战

互联网应用离不开用户身份验证。传统的流程通常如下:

  1. 用户提交用户名和密码给服务器。
  2. 服务器验证通过后,会在当前会话中存储用户信息,例如用户角色、登录时间等。
  3. 服务器返回一个session_id给用户,并写入用户的cookie。
  4. 用户后续请求都会通过cookie发送session_id给服务器。
  5. 服务器根据session_id查找用户信息,确定用户身份。

这种模式的扩展性差。在单机环境下可行,但在服务器集群或跨域微服务架构中,需要会话数据共享,每个服务器都能访问会话数据。例如,网站A和网站B属于同一公司,希望用户登录其中一个网站后,访问另一个网站也能自动登录,该如何实现?

一种方案是将会话数据持久化到数据库或其他存储层,各个服务请求数据时访问持久层。这种方法架构清晰,但工作量大,且持久层故障会造成单点故障。

另一种方案是服务器不存储会话数据,所有数据都保存在客户端,随每次请求发送给服务器。JWT正是这种方案的典型代表。

二、JWT的工作原理

JWT的原理是服务器验证用户身份后,生成一个JSON对象并返回给用户,例如:

<code>{"name": "alice", "role": "admin", "expiration time": "0:00, july 1, 2024"}</code>

用户后续与服务器通信时,需要携带此JSON对象。服务器根据此对象验证用户身份。为了防止数据篡改,服务器生成对象时会添加签名(具体细节稍后介绍)。

服务器不再保存会话数据,成为无状态服务器,更容易实现扩展。

三、JWT的数据结构

实际的JWT是一个长字符串,由点(.)分隔成三部分:

掌握 JWT(JSON Web 令牌):深入探讨

为了便于阅读,这里分行显示,实际JWT中没有换行符。

三部分分别为:

  • Header (头部)
  • Payload (有效载荷)
  • Signature (签名)

写成一行,格式为:Header.Payload.Signature

掌握 JWT(JSON Web 令牌):深入探讨

下面分别介绍这三部分:

3.1 Header (头部)

Header是一个JSON对象,描述JWT的元数据,通常如下:

<code>{"alg": "HS256", "typ": "JWT"}</code>

alg属性表示签名算法(algorithm),默认为HMAC SHA256 (HS256);typ属性表示token类型,JWT token统一为"JWT"。

使用Base64Url算法将JSON对象转换为字符串(稍后详细介绍)。

3.2 Payload (有效载荷)

Payload也是一个JSON对象,存储实际需要传输的数据。JWT定义了7个标准字段:

  • iss (Issuer): 发行者
  • exp (Expiration Time): 过期时间
  • sub (Subject): 主题
  • aud (Audience): 观众
  • nbf (Not Before): 生效时间
  • iat (Issued At): 发行时间
  • jti (JWT ID): 唯一标识符

除了标准字段,还可以自定义私有字段。例如:

FaceSwapper
FaceSwapper

FaceSwapper是一款AI在线换脸工具,可以让用户在照片和视频中无缝交换面孔。

下载
<code>{"sub": "1234567890", "name": "john doe", "admin": true}</code>

注意,JWT默认不加密,任何人都可读取。因此,不要在Payload中放置敏感信息。

Payload也需要使用Base64Url算法转换为字符串。

3.3 Signature (签名)

Signature是前两部分的签名,用于防止数据篡改。

需要一个密钥(secret),只有服务器知道,不能泄露。使用Header中指定的签名算法(默认为HMAC SHA256),根据以下公式生成签名:

<code>HMACSHA256(base64UrlEncode(header) + "." + base64UrlEncode(payload), secret)</code>

计算出签名后,将Header、Payload、Signature组合成一个字符串,用点(.)分隔,返回给用户。

3.4 Base64Url

Header和Payload的编码算法是Base64Url。它与Base64类似,但对URL不安全的字符进行了替换:=省略,+替换为-/替换为_

四、JWT的使用方法

客户端收到JWT后,可以存储在cookie或localStorage中。

每次与服务器通信时,需要携带JWT。可以将其放在HTTP请求头的Authorization字段中:

Authorization: Bearer <jwt></jwt>

或者在跨域请求时,将其放在POST请求的数据体中。

五、JWT的特点

(1) JWT默认不加密,但可以加密。

(2) 未加密的JWT不能存储敏感数据

(3) JWT不仅用于身份验证,也可用于信息交换。

(4) JWT最大的缺点是服务器不保存会话状态,无法在使用过程中撤销令牌或更改权限。

(5) JWT本身包含认证信息,一旦泄露,任何人都可获得权限。应设置较短的有效期,并对重要权限进行二次验证。

(6) JWT应通过HTTPS传输,避免明文传输。

Leapcell:最佳无服务器平台

掌握 JWT(JSON Web 令牌):深入探讨

推荐一个部署Web服务的优秀平台:Leapcell

1. 多语言支持

  • 支持JavaScript、Python、Go或Rust开发。

2. 免费部署无限项目

  • 只需支付使用费用,无请求不收费。

3. 高性价比

  • 按需付费,无闲置费用。

4. 简化的开发者体验

  • 直观的用户界面,轻松设置。
  • 自动化的CI/CD管道和GitOps集成。
  • 实时指标和日志记录。

5. 可扩展性和高性能

  • 自动缩放,轻松处理高并发。
  • 零运营开销。

掌握 JWT(JSON Web 令牌):深入探讨

更多信息请访问Leapcell文档!

Leapcell Twitter: https://www.php.cn/link/86fd6c86e53687c67e50bd29a08b133e

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
C++系统编程内存管理_C++系统编程怎么与Rust竞争内存安全
C++系统编程内存管理_C++系统编程怎么与Rust竞争内存安全

C++系统编程中的内存管理是指 对程序运行时内存的申请、使用和释放进行精细控制的机制,涵盖了栈、堆、静态区等不同区域,开发者需要通过new/delete、智能指针或内存池等方式管理动态内存,以避免内存泄漏、野指针等问题,确保程序高效稳定运行。它核心在于开发者对低层内存有完全控制权,带来灵活性,但也伴随高责任,是C++性能优化的关键。

13

2025.12.22

Rust异步编程与Tokio运行时实战
Rust异步编程与Tokio运行时实战

本专题聚焦 Rust 语言的异步编程模型,深入讲解 async/await 机制与 Tokio 运行时的核心原理。内容包括异步任务调度、Future 执行模型、并发安全、网络 IO 编程以及高并发场景下的性能优化。通过实战示例,帮助开发者使用 Rust 构建高性能、低延迟的后端服务与网络应用。

9

2026.02.11

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

213

2026.03.05

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

454

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

334

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

cookie
cookie

Cookie 是一种在用户计算机上存储小型文本文件的技术,用于在用户与网站进行交互时收集和存储有关用户的信息。当用户访问一个网站时,网站会将一个包含特定信息的 Cookie 文件发送到用户的浏览器,浏览器会将该 Cookie 存储在用户的计算机上。之后,当用户再次访问该网站时,浏览器会向服务器发送 Cookie,服务器可以根据 Cookie 中的信息来识别用户、跟踪用户行为等。

6500

2023.06.30

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

4

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号