JWT的介绍与在Fastapi框架中的应用

什么是JWT

JWT (JSON Web Token) 是一个开放标准 ( RFC 7519 ),它定义了一种紧凑且自包含的方式,用于在各方之间安全地以 JSON 对象的形式传输信息。由于这些信息经过数字签名,因此可以被验证和信任。JWT 可以使用密钥(采用HMAC算法)或使用RSA或ECDSA 的公钥/私钥对进行签名。

虽然 JWT 可以通过加密来保障各方之间的隐私,但我们将重点介绍签名令牌。签名令牌可以验证其所含声明的完整性,而加密令牌则会向其他方隐藏这些声明。使用公钥/私钥对对令牌进行签名时,签名还能证明只有持有私钥的一方才是签名者。

JWT应用场景

以下是 JSON Web Tokens 有用的一些场景:

  • 授权:这是使用 JWT 最常见的场景。用户登录后,每个后续请求都将包含 JWT,允许用户访问该令牌允许的路由、服务和资源。单点登录是如今 JWT 广泛使用的一项功能,因为它开销小,并且易于跨域使用。

  • 信息交换:JSON Web Token 是各方之间安全传输信息的有效方式。由于 JWT 可以签名(例如,使用公钥/私钥对),因此您可以确保发送者的身份与其声明相符。此外,由于签名是使用标头和有效负载计算得出的,因此您还可以验证内容未被篡改。

JSON Web Token 结构是什么?

JSON Web Token由以下三部分组成,中间用点连接:

  • 标题
  • 有效载荷
  • 签名

标题

标头通常由两部分组成:令牌的类型(即 JWT)和正在使用的签名算法(例如 HMAC SHA256 或 RSA)。

例如:

{"alg": "HS256","typ": "JWT"
}

然后,将此 JSON 经过Base64Url编码,形成 JWT 的第一部分。

有效载荷

令牌的第二部分是有效负载,其中包含声明。声明是关于实体(通常是用户)及其附加数据的声明。声明分为三种类型:已注册声明、公共声明和私有声明。

声明:这些是一组预定义的声明,虽然不是强制性的,但建议使用,以提供一组有用且可互操作的声明。其中包括: iss(颁发者)、 exp(到期时间)、 sub(主题)、 aud(受众)等。

请注意,由于 JWT 要求紧凑,因此声明名称只有三个字符。

有效载荷示例如下:

{"sub": "1234567890","name": "John Doe","admin": true
}

然后对有效负载进行Base64Url编码以形成 JSON Web Token 的第二部分。

请注意,对于签名令牌,这些信息虽然受到保护以防止篡改,但任何人都可以读取。除非已加密,否则请勿将机密信息放入 JWT 的有效负载或标头元素中。

签名

要创建签名部分,您必须获取编码的标头、编码的有效负载、秘密、标头中指定的算法,然后对其进行签名。

例如,如果您想使用 HMAC SHA256 算法,则签名将以以下方式创建:

HMACSHA256(base64UrlEncode(header) + "." +base64UrlEncode(payload),secret)

签名用于验证消息在传输过程中未被更改,并且,在使用私钥签名的令牌的情况下,它还可以验证 JWT 的发送者是否是其声称的那个人。

整合

输出是三个由点分隔的 Base64-URL 字符串,可以在 HTML 和 HTTP 环境中轻松传递,同时与基于 XML 的标准(如 SAML)相比更加紧凑。

下面显示了一个对前面的标头和有效负载进行了编码的 JWT,并且使用密钥进行了签名。 编码的 JWT

如果您想使用 JWT 并将这些概念付诸实践,可以使用jwt.io Debugger来解码、验证和生成 JWT。

JWT.io 调试器

JSON Web Tokens 如何工作?

在身份验证中,当用户使用其凭证成功登录时,将返回一个 JSON Web Token。由于 token 是凭证,因此必须格外小心,以防止出现安全问题。通常情况下,不应将 token 保留超过规定时间。并且由于缺乏安全性,也不应将敏感的会话数据存储在浏览器存储中。

每当用户想要访问受保护的路由或资源时,用户代理都应该发送 JWT,通常在请求头的Authorization标头中使用Bearer模式。标头内容应如下所示:

Authorization: Bearer <token>

下图展示了如何获取 JWT 以及如何使用它来访问 API 或资源:
JWT工作流程

  1. 应用程序或客户端向授权服务器请求授权。
  2. 当授权被授予时,授权服务器会向应用程序返回访问令牌。
  3. 应用程序使用访问令牌来访问受保护的资源(如 API)。

未完待续。。。

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

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

相关文章

dfs第二次加训 详细题解 下

目录 B4158 [BCSP-X 2024 12 月小学高年级组] 质数补全 思路 B4279 [蓝桥杯青少年组国赛 2023] 数独填数、 思路 P5198 [USACO19JAN] Icy Perimeter S 思路 P5429 [USACO19OPEN] Fence Planning S 思路 P6111 [USACO18JAN] MooTube S 思路 P6207 [USACO06OCT] Cows …

配置Hadoop集群环境准备

&#xff08;一&#xff09;Hadoop的运行模式 一共有三种&#xff1a; 本地运行。伪分布式完全分布式 &#xff08;二&#xff09;Hadoop的完全分布式运行 要模拟这个功能&#xff0c;我们需要做好如下的准备。 1&#xff09;准备3台客户机&#xff08;关闭防火墙、静态IP、…

Python60日基础学习打卡D12【虫豸版】

退火算法 物理现象&#xff1a;退火现象指物体逐渐降温的物理现象&#xff0c;温度愈低&#xff0c;物体的能量状态会低&#xff1b;温度足够低后&#xff0c;液体开始冷凝与结晶&#xff0c;在结晶状态时&#xff0c;系统的能量状态最低。大自然在缓慢降温(即退火)时&#xf…

1.3.1 Linux音频框架alsa详细介绍

ALSA作为对旧OSS系统的替代方案&#xff0c;始于1998年。当时OSS还闭源商业化&#xff0c;因此社区开始开发开源的ALSA。经过多年的发展&#xff0c;ALSA成为Linux内核中音频架构的标准。 结构和架构 ALSA由以下几个主要部分组成&#xff1a; 内核模块&#xff1a; 这是ALSA的…

# 07_Elastic Stack 从入门到实践(七)---1

07_Elastic Stack 从入门到实践(七)—1 一、Filebeat入门之读取 Nginx 日志文件 1、首先启动 Elasticsearch 集群 和 Nginx 服务,打开GoogleChrome 浏览器,点击 elasticsearch-head 插件,连接Elasticsearch 集群 服务器。 # 查看网卡名 $ ip addr# 修改网卡配置,改为…

BUUCTF 大流量分析(三) 1

BUUCTF:https://buuoj.cn/challenges 文章目录 题目描述&#xff1a;密文&#xff1a;解题思路&#xff1a;flag&#xff1a; 相关阅读 CTF Wiki BUUCTF | 大流量分析 &#xff08;一&#xff09;&#xff08;二&#xff09;&#xff08;三&#xff09; 题目描述&#xff1a; …

数据库的进阶操作

目录 1、数据库的约束 2、查询操作的进阶 2.1 查询插入 2.2 聚合查询 2.3 运算查询 2.3 分组查询 2.4 联合查询 2.5 内外连接 2.6 子查询 2.7 合并查询 1、数据库的约束 数据库的约束是指&#xff1a;数据库会自动的对数据的合法性进行校验和检查的一系列操作的机制&a…

.Net HttpClient 使用请求数据

HttpClient 使用请求数据 0、初始化及全局设置 //初始化&#xff1a;必须先执行一次 #!import ./ini.ipynb1、使用url 传参 参数放在Url里&#xff0c;形如&#xff1a;http://www.baidu.com?namezhangsan&age18, GET、Head请求用的比较多。优点是简单、方便&#xff0…

Qt还有希望吗

&#x1f680;2025 年 Qt 框架价值大揭秘&#xff01;会持续闪耀吗&#xff1f; 宝子们&#xff0c;今天来聊聊 Qt 框架在 2025 年的价值走向&#xff0c;这可是跨平台应用开发的宝藏工具呀&#xff01; &#x1f31f;核心优势稳稳拿捏Qt 的跨平台能力绝了&#xff01; Windows…

Redis设计与实现——数据结构与对象

简单动态字符串&#xff08;SDS&#xff09; SDS 的结构定义 len&#xff1a;记录当前字符串的实际长度&#xff08;不包含 \0&#xff09;&#xff0c;获取长度的时间复杂度为 O(1)。free&#xff1a;记录未使用的空间大小&#xff0c;用于优化内存分配。buf[]&#xff1a;实…

NeurIPS 2025 截稿攻略

会议资讯 NeurIPS&#xff0c;全称神经信息处理系统大会&#xff0c;是一个关于机器学习和计算神经科学的国际会议。NeurIPS是CCF&#xff08;计算机学会&#xff09;推荐的A类会议&#xff01;是机器学习领域内最具难度、水平最高且影响力最强的会议之一。它与ICML&#xff0…

Java中堆栈

文章目录 Java中堆栈1. 栈&#xff08;Stack&#xff09;特点示例 2. 堆&#xff08;Heap&#xff09;特点示例 3. 核心区别4. 常见问题5. 内存可视化示例内存布局示意图&#xff1a; 总结 Java中堆栈 在 Java 中&#xff0c;“堆栈” 通常指的是堆&#xff08;Heap&#xff0…

【类拷贝文件的运用】

常用示例 当我们面临将文本文件分成最大大小块的时&#xff0c;我们可能会尝试编写如下代码: public class TestSplit {private static final long maxFileSizeBytes 10 * 1024 * 1024; // 默认10MBpublic void split(Path inputFile, Path outputDir) throws IOException {…

打破产品思维--被讨厌的勇气--实战5

课程&#xff1a;B站大学 记录产品经理实战项目系统性学习&#xff0c;从产品思维&#xff0c;用户画像&#xff0c;用户体验&#xff0c;增长数据驱动等不同方向理解产品&#xff0c;从0到1去理解产品从需求到落地的全过程&#xff0c;测试左移方向&#xff08;靠近需求、设计…

【Autosar SecOC 1.信息安全原理介绍】

这里写目录标题 1 背景2 了解黑客攻击原理3 SecOC实现数据的真实性与完整性校验3.1 数据身份验证完成真实性验证3.2 防止重放攻击 1 背景 在今天的车载网络中&#xff0c;大部分数据传输是在没有任何特殊安全措施的情况下进行的。因此&#xff0c;一旦能够直接访问车辆的总线&a…

基于SpringBoot的校园周边美食探索及分享平台【附源码+数据库+文档下载】

一、项目简介 本项目是一个基于 SpringBoot Vue 的校园周边美食探索与分享平台&#xff0c;专为在校大学生开发&#xff0c;集美食推荐、好友互动、收藏分享于一体。 通过平台&#xff0c;用户可以探索学校周边的美食店铺、发布美食鉴赏、添加好友进行交流分享。同时&#x…

无偿帮写毕业论文

以下教程教你如何利用相关网站和AI免费帮你写一个毕业论文。毕竟毕业论文只要过就行&#xff0c;脱产学习这么多年&#xff0c;终于熬出头了&#xff0c;完成毕设后有空就去多看看亲人好友&#xff0c;祝好&#xff01; 一、找一个论文模板(最好是overleaf) 废话不多说&#…

15 个 Azure DevOps 场景化面试问题及解答

问题 1. 解释 Azure DevOps YAML 管道的典型结构。 您可以从管道的整体结构开始&#xff0c;从触发器开始。您也可以选择解释它可能包含的不同类型的阶段&#xff1a;构建、测试、扫描、部署等。 Azure DevOps YAML 管道结构示例 触发器指示管道运行。它可以是持续集成 (CI) 或…

Java 大视界 -- Java 大数据机器学习模型在元宇宙虚拟场景智能交互中的关键技术(239)

&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎来到 青云交的博客&#xff01;能与诸位在此相逢&#xff0c;我倍感荣幸。在这飞速更迭的时代&#xff0c;我们都渴望一方心灵净土&#xff0c;而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识&#xff0c;也…

本地不安装oracle,还想连oracle

1.首先要用navicat,或者toad打开连接数据库 2.安装oracle客户端&#xff0c;有时候OCI.dll需要看数据库版本&#xff0c;我们Oracle数据库是12C&#xff0c;可以用这个版本 3. 4.配置环境变量 变量名&#xff1a;NLS_LANG变量值&#xff1a;SIMPLIFIED CHINESE_CHINA.ZHS16GBK …