当前位置: 首页 > article >正文

什么是JWT

JWT是什么

JWT全称(Json web token),JWT是一种标准,用于以JSON对象的形式在各方之间安全的传输信息。

JWT的组成部分

  • Header
  • Payload
  • Signature

JWT通常看起来像这样:
xxxxx.yyyyy.zzzzz
接下来让我们对其三个组成部分进行拆分讲解。

Header

header由两部分组成,第一部分是token的类型(JWT),第二部分是加密算法的名称(如SHA256、RSA和HMAC)。
例如:

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

这段JSON将被使用Base64Url编码,然后作为JWT的一部分。
999999999999999999999999999999999999999999999999999999999999

Payload

JWT token的第二部分是包含了声明的负载。声明是陈述某个实体(通常式用户),及其附加数据的陈述99。声明的类型由三种:注册声明、公共声明和私有声明:

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

  • 公共声明(public claims):这些声明可以根据使用 JWT 的需求自由定义。为了避免冲突,它们应该在 IANA JSON Web Token 注册表中定义,或者作为一个包含防冲突命名空间的 URI 来定义。

  • 私有声明(private claims):这是为了在同意使用它们的各方之间共享信息而创建的自定义声明,既不是注册声明也不是公共声明

注意,声明名称长度仅为三个字符,因为 JWT 设计为紧凑型格式。

示例:

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

第二部分同样需要进行Base64Url编码。JWT是防篡改的,但是任何人都可以读取。除非加密,否则不要将机密信息放入JWT的有效负载或者标题元素中。

Signature

创建签名部分,需要取编码后的头部,编码后的负载,一个密钥以及头部中指定的算法进行签名。

例如:如果要使用 HMAC SHA256 算法,签名将按照以下方式创建:

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

签名用于验证消息在传输过程中未被篡改,并且,在使用私钥签名的情况下,还可以验证 JWT 发送者的身份是否如其所声称的一样。

综合

jwt最终是以三个点分隔的Base64-URL字符串。l


http://www.kler.cn/news/318015.html

相关文章:

  • 初识模版!!
  • 英伟达NVIDIA数字IC后端笔试真题(ASIC Physical Design Engineer)
  • AI大模型教程 Prompt提示词工程 AI原生应用开发零基础入门到实战【2024超细超全,建议收藏】
  • 低空经济火爆,稀缺无人机教员培训详解
  • [产品管理-33]:实验室技术与商业化产品的距离,实验室技术在商业化过程中要越过多少道“坎”?
  • 在Windows上使用谷歌浏览器进行离线浏览的方法
  • Vue学习记录之九(插槽slot)
  • C/C++面试题
  • MySQL的msi版本9.0在安装过程总结和需要注意的地方
  • YOLOX预测图片是无法保存
  • 【AI小项目5】使用 KerasNLP 对 Gemma 模型进行 LoRA 微调
  • 【工具类】——图片缩放
  • 掌握Python办公自动化,轻松成为职场高效达人
  • CSS中的root的作用
  • 软件测试面试八股文(含文档)
  • 若依框架下项目,通过Nginx进行双服务部署
  • 使用k8s搭建mariadb+nginx+wordpress
  • JAVA毕业设计181—基于Java+Springboot+vue3的潮鞋交易管理系统(源代码+数据库+开题+万字论文)
  • 《华为三台交换机堆叠的详细命令行配置示例》
  • 观察者模式(发布-订阅模式)
  • Moshi: a speech-text foundation model for real time dialogue
  • 828华为云征文 | 解锁企业级邮件服务,在华为云Flexus x实例上部署Mailcow开源方案
  • ONNX模型部署利器ONNXRUNTIME框架
  • 算法-Init
  • [sniffer]分析
  • Excel 冻结多行多列
  • Python机器学习基础(NumPy、Pandas、Matplotlib)
  • 【CPP11?】结合CPP发展历史来理解CPP11
  • 代码随想录算法训练营Day14 | 226.翻转二叉树、101. 对称二叉树、104.二叉树的最大深度、111.二叉树的最小深度
  • 【MySQL内置数据库】information_schema