JWT 的核心工作原理是什么?集群中的其他 服务如何验证这个JWT 呢?

JWT(JSON Web Token)是一种用于身份验证和信息交换的紧凑、URL 安全的令牌。JWT 的核心工作原理包括三个主要部分:头部(Header)、载荷(Payload)和签名(Signature)。以下是对 JWT 核心工作原理的详细解释以及在集群环境中如何验证 JWT 的说明。

JWT 核心工作原理

  1. 头部(Header)

    • 头部通常包括令牌类型(即 "JWT")和所使用的签名算法(如 HMAC SHA256 或 RSA)。
    • 例如:
      {"alg": "HS256","typ": "JWT"
      }
      
  2. 载荷(Payload)

    • 载荷包含声明(claims),即要传递的用户信息。声明有三种类型:
      • 注册声明(Registered claims):一组预定义的声明,不是强制性的,但推荐使用,如 iss(发行者)、exp(到期时间)、sub(主题)、aud(受众)。
      • 公共声明(Public claims):可以由用户定义,但应避免冲突。
      • 私有声明(Private claims):自定义的声明,用于信息交换。
    • 例如:
      {"sub": "1234567890","name": "John Doe","admin": true
      }
      
  3. 签名(Signature)

    • 为了确保令牌的完整性和真实性,JWT 会对头部和载荷进行签名。
    • 签名的生成步骤:
      1. 将头部和载荷分别进行 Base64Url 编码。
      2. 将编码后的头部和载荷用句点(.)连接起来。
      3. 使用指定的算法和一个密钥对连接后的字符串进行签名。
    • 例如,对于 HMAC SHA256 算法:
      HMACSHA256(base64UrlEncode(header) + "." + base64UrlEncode(payload),secret
      )
      

JWT 的生成和验证

  1. 生成 JWT

    • 服务器在用户登录成功后,创建一个 JWT,包括头部、载荷,并使用密钥签名。
    • 生成的 JWT 通过 HTTP 响应返回给客户端。
  2. 验证 JWT

    • 客户端在后续请求中将 JWT 放在 HTTP 请求头的 Authorization 字段中发送给服务器。
    • 服务器接收到请求后,提取 JWT,使用相同的签名算法和密钥验证签名的有效性。
    • 如果签名有效且令牌未过期,则允许访问资源。

集群环境中的 JWT 验证

在集群环境中,多个服务实例可能需要验证 JWT。为了实现这一点,通常有以下几种方法:

  1. 共享密钥

    • 对于对称加密算法(如 HMAC SHA256),所有服务实例共享同一个密钥来签名和验证 JWT。
    • 缺点是密钥必须在所有实例之间安全地分发和存储。
  2. 使用公钥/私钥对

    • 对于非对称加密算法(如 RSA 或 ECDSA),使用私钥签名 JWT,使用公钥验证 JWT。
    • 发行者服务持有私钥,签发 JWT。验证者服务持有公钥,验证 JWT。
    • 公钥可以公开分发,安全性更高且易于管理。
  3. 集中认证服务

    • 实现一个专门的认证服务,负责签发和验证 JWT。其他服务在需要时调用该认证服务进行 JWT 验证。
    • 这种方法可以集中管理密钥,提高安全性和灵活性,但引入了额外的服务调用开销。

具体实现

共享密钥的示例

假设我们使用对称加密(HMAC SHA256),以下是共享密钥的生成和验证过程:

生成 JWT

import jwt
import datetimesecret = 'my_secret_key'
payload = {'sub': '1234567890','name': 'John Doe','iat': datetime.datetime.utcnow(),'exp': datetime.datetime.utcnow() + datetime.timedelta(hours=1)
}token = jwt.encode(payload, secret, algorithm='HS256')
print(token)

验证 JWT

import jwttoken = 'eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9...'  # 接收到的 JWT
secret = 'my_secret_key'try:decoded_payload = jwt.decode(token, secret, algorithms=['HS256'])print(decoded_payload)
except jwt.ExpiredSignatureError:print('Token has expired')
except jwt.InvalidTokenError:print('Invalid token')

使用公钥/私钥对的示例

假设我们使用非对称加密(RSA),以下是生成和验证 JWT 的过程:

生成 JWT

import jwt
import datetimeprivate_key = '''-----BEGIN RSA PRIVATE KEY-----
MIIEowIBAAKCAQEA2LV5N2G3F6vA...
-----END RSA PRIVATE KEY-----'''payload = {'sub': '1234567890','name': 'John Doe','iat': datetime.datetime.utcnow(),'exp': datetime.datetime.utcnow() + datetime.timedelta(hours=1)
}token = jwt.encode(payload, private_key, algorithm='RS256')
print(token)

验证 JWT

import jwttoken = 'eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9...'  # 接收到的 JWT
public_key = '''-----BEGIN PUBLIC KEY-----
MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A...
-----END PUBLIC KEY-----'''try:decoded_payload = jwt.decode(token, public_key, algorithms=['RS256'])print(decoded_payload)
except jwt.ExpiredSignatureError:print('Token has expired')
except jwt.InvalidTokenError:print('Invalid token')

结论

JWT 的核心工作原理是通过头部、载荷和签名确保令牌的完整性和安全性。在分布式系统中,可以通过共享密钥或公钥/私钥对实现 JWT 的验证。采用非对称加密时,私钥用于签名,公钥用于验证,这种方式安全性更高且易于管理。集中认证服务也是一种有效的实现方式,但需要权衡性能和安全性。

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

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

相关文章

《Python 第三方模块包安装指南》

在 Python 编程中,第三方模块包极大地丰富了其功能,让我们能够更高效地完成各种任务。下面将为您详细介绍如何安装 Python 的第三方模块包。 一、使用 pip 命令安装 pip 是 Python 的包管理工具,大多数情况下,我们可以通过以下命令来安装第三方模块包:pip install 模块包名…

巴图自动化Modbus转PN网关模块连智能仪表与PLC通讯

通过巴图自动化Modbus转Profinet协议网关模块,实现PLC对仪表设备的远程监控和数据传输,提高生产效率和运行稳定性。巴图自动化Modbus转Profinet协议转换BT-MDPN100网关模块的主要功能是实现Modbus协议和Profinet协议之间的转换和通信。Modbus 转 Profinet协议网关模块集成了M…

一文搞懂到底什么是 AQS

日常开发中,我们经常使用锁或者其他同步器来控制并发,那么它们的基础框架是什么呢?如何实现的同步功能呢?本文将详细用白话讲解构建锁和同步器的基础框架--AQS,并根据源码分析其原理。前言 日常开发中,我们经常使用锁或者其他同步器来控制并发,那么它们的基础框架是什么…

flutter状态管理 provider使用

provider是flutter官方推荐的状态管理插件,是基于InheritedWidget实现的。 下面我们来讲一个provider的使用方法。 1.在pubspec.yaml文件中添加 provider: ^6.1.2 开发文档:https://pub-web.flutter-io.cn/packages/provider 可以查看使用方法和最新版本号。 添加完成后…

企业数字化转型:顶层规划方法

随着数字化时代的到来,发生了以数字化、智能化为典型特征的新一轮科技革命,各行各业利用互联网、大数据、云计算、人工智能、区块链技术对传统产业进行全方位、全链条改造,实施“上云用数赋智”行动,全面推进各行业数字化转型。数字经济的大门已然开启,数字经济顶层战略规…

Nuxt3 的生命周期和钩子函数(十)

摘要:本文详细介绍了Nuxt3框架中的五个webpack钩子函数:webpack:configResolved用于在webpack配置解析后读取和修改配置;webpack:compile在编译开始前调用,可修改编译选项;webpack:compiled在编译完成后调用,可处理编译结果;webpack:change在开发模式下文件变化时触发,…

Jenkins汉化

1、Jenkins版本:版本2.426.3) Manage Jenkins->选择Plugins->切换到Availabled plugin->搜索local,然后选中安装,如下图所示 2、安装完成后重启Jenkins,汉化完成。如下图所示 像个小学生一样努力学习

模拟集成电路设计系列博客——9.1 比较器

模拟集成电路设计 9.1 比较器 比较器可能是继放大器之后第二常用的电路元件,比较器用于判断一个信号是否大于或小于零,或者比较一个信号是否大于另一个。如我们之前的章节所见,比较器在ADC中非常常用。在其他的应用中也经常出现比较器,例如数据传输,开关电源稳压器等等。 …

prufer序列

prufer序列用途: 将带标号的树用唯一的整数序列表示出来,证明凯莱公式。构造方法:每次选择一个编号最小的叶结点并删掉它,然后在序列中记录下它连接到的那个结点。重复\(n-2\)次后就只剩下两个结点,算法结束。 举个栗子(本图来自baoziwu2,侵删)显然可以有一个用堆做的方法,…

【冷启动#2】实用的springboot tutorial入门demo

跟着官方文档熟悉一遍创建spring工程的步骤 https://spring.io/guides/gs/spring-boot https://juejin.cn/post/7077958723829760008 demo简介 整个demo的预期目标是: 管理一堆玩家的数据,数据库使用的是现成的我们虚拟机上安装的MySQL 项目结构参考 主要工作:创建并熟悉spr…

CentOS8部署zerotier异地组网

本文介绍了在CentOS 8系统上部署ZeroTier以实现异地组网的方法,包括安装、配置、加入网络、开启IP转发和设置路由表等步骤,并提出进一步实现公网无缝组网的展望。CentOS8部署zerotier异地组网 CentOS8部署zerotier异地组网 一、前言 本文在此前研究部署FRP进行内网穿透,但FR…

《DNK210使用指南 -CanMV版 V1.0》第九章 打印输出实验

第九章 打印输出实验 1)实验平台:正点原子DNK210开发板 2)章节摘自【正点原子】DNK210使用指南 - CanMV版 V1.0 3)购买链接:https://detail.tmall.com/item.htm?&id=782801398750 4)全套实验源码+手册+视频下载地址:http://www.openedv.com/docs/boards/k210/ATK-DN…

分享一款可编辑本地电脑文件的在线编辑器

之前见过在线版的VSCode,被惊讶到了。网页上竟然可以编辑电脑本地的文件,打破了网页无法编辑本地电脑文件的限制。一直好奇怎么做的。抽空研究了一下,然后发现其实也不难。背景 之前见过在线版的VSCode,被惊讶到了。网页上竟然可以编辑电脑本地的文件,打破了网页无法编辑本…

xhcms

xhcms 目录结构 admin --管理后台文件夹 css --存放css的文件夹 files --存放页面的文件夹 images --存放图片的文件夹 inc --存放网站配置文件的文件夹 install --网站进行安装的文件夹 seacmseditor --编辑器文件夹 templ…

lrzsz安装完成后rz乱码

rz选择文件夹后乱码传输不到linux里面, 这时候只需要rz -be再选择文件 这样就可以进行后续的解压了tar -zxvf jdk-8u65-linux-x64.tar.gz

椭流线法设计配光器

本文介绍了利用椭流线法设计高效均匀的LED配光器,通过对边光原理、反射定律及椭圆几何特性的深入分析,结合Matlab和SolidWorks软件实现光学仿真,最终成功设计出接收效率高、均匀度优的配光器。椭流线法设计配光器 椭流线法设计配光器 一、设计原理 1、边光原理 边光原理是非…

wx云开发增删改查

首先是.wxml文件,此处为固定数据的新增<button type="primary" bind:tap="addData"> //调用.js中addData方法插入数据 </button>对应.js文件//添加数据addData(){wx.showLoading({ //showLoading(api接口)(防止用户多次…

剪裁法设计配光器

剪裁法设计配光器通过光源角分割和目标面分割,利用边光原理和反射定律,计算并构建光学母线,以实现高均匀度和高光效的均匀圆斑光学设计。剪裁法设计配光器 剪裁法设计配光器 一、设计原理边光原理 边光原理是非成像光学中的一个基础原理,其内容可以表述为:来自光源边缘的光…

iOS-列表视图

在iOS开发中,UITableView和UICollectionView是两个非常核心的用于展示集合数据的UI组件。它们都能以列表的形式展示数据,但各自的特点和使用场景有所不同。 UITableView UITableView用于展示和管理垂直滚动的单列数据列表。它是以行的形式展示数据,每行(cell)可以展示相同…

CPC配光系统设计

本文详细介绍了CPC(复合抛物线聚光器)配光系统的设计过程,包括设计原理、抛物流线几何特性及其设计要求和流程,并通过Matlab和SolidWorks绘制模型,最后在TracePro中进行仿真验证,确保系统满足均匀照度和高效接收率的目标。CPC配光系统设计 CPC配光系统设计 一、设计原理 …