0

0

了解 JWE:结构、操作、优点、缺点以及如何创建 JWE

花韻仙語

花韻仙語

发布时间:2024-12-23 13:30:24

|

1179人浏览过

|

来源于dev.to

转载

1. 什么是jwe(json web加密)?

image

json web 加密 (jwe) 是 rfc 7516 定义的标准,它使用基于 json 的数据结构表示加密内容。它允许您加密任意有效负载以确保机密性和完整性(如果需要)。此加密内容可以包括任何类型的数据,例如敏感的用户信息、安全令牌甚至文件。

1.1 为什么使用jwe?

image

jwe 广泛用于 web 应用程序和 api,以安全地传输敏感数据,例如令牌、用户信息和财务详细信息。它确保信息即使被拦截也无法被未经授权的实体读取。加密的有效负载只能由拥有正确解密密钥的预期接收者解密和使用。

1.2 jwe 的主要特点

  • 保密性:jwe 的首要目标是确保内容的机密性。
  • 完整性:保证数据在传输过程中不被篡改。
  • 互操作性:jwe 与不同的加密算法和环境兼容。
  • 紧凑性:jwe 提供了一种紧凑的表示形式,易于通过 http 传输。

2. jwe的结构

image

json web 加密 (jwe) 是一种以 json 对象的形式在各​​方之间安全传输信息的标准。 jwe 使用加密来确保其保护的数据的机密性和完整性。典型的 jwe 结构由五个部分组成,这些部分连接在一起并用句点 (.) 分隔。这五个部分是:

  • 标题(何塞标题)
  • 加密密钥
  • 初始化向量
  • 密文
  • 身份验证标签

jwe 的每个部分在加密和解密过程中都扮演着特定的角色。让我们详细研究每个部分。

2.1 jose 标头(json 对象签名和加密标头)

jose(json 对象签名和加密)标头是 jwe 的第一部分,包含有关加密过程的元数据。它是一个 base64url 编码的 json 对象,其中包括:

  • alg (算法):指定用于加密内容加密密钥 (cek) 的算法。常见算法包括 rsa-oaeprsa1_5a128kwa256kw
  • enc(加密算法):表示用于加密有效负载(明文)的加密算法。示例包括 a128gcma256gcma128cbc-hs256
  • typ(类型):可选地指示令牌的类型,通常是 jwt。
  • cty(内容类型):如果加密负载不是默认的 application/json,则可以选择指示加密负载的内容类型。

示例:

{
  "alg": "rsa-oaep",
  "enc": "a256gcm"
}

此标头指定使用 rsa-oaep 算法对内容加密密钥进行加密,并使用 aes gcm 和 256 位密钥对有效负载进行加密。

2.2 加密密钥

jwe 的第二部分是加密密钥,它是用于加密实际数据(有效负载)的密钥。该密钥使用 jose 标头的 alg 参数中指定的算法进行加密。

  • 如果 algrsa-oaep ,则内容加密密钥 (cek) 使用 rsa-oaep 算法和接收者的公钥进行加密。
  • 如果 alga128kwa256kw ,则使用对称密钥包装。

加密密钥采用 base64url 编码。

2.3 初始化向量(iv)

初始化向量 (iv) 是 jwe 结构中的第三个组成部分。它是一个 base64url 编码的随机值,与加密算法一起使用,以确保相同的明文每次都会进行不同的加密。 iv 可以防止加密数据中出现模式,从而增强安全性。

对于 aes gcm 模式,iv 通常为 96 位(12 字节)长。

2.4 密文

密文是使用内容加密密钥(cek)和加密算法(enc 参数)对明文(有效负载数据)进行加密的结果。密文采用 base64url 编码,是 jwe 的核心部分,因为它保存受保护的内容。

  • 加密过程包括填充、加密以及将加密输出转换为base64url格式。
  • 如果包含额外的验证数据 (aad),则用于确保 jose 标头和密文的真实性和完整性。

2.5 认证标签

身份验证标签(也称为 标签)是一个 base64url 编码值,为密文、初始化向量 (iv) 和附加验证数据提供完整性和真实性(aad)。它是在使用 aes gcm 等算法的加密过程中生成的。

如果加密后 jwe 结构的任何部分被更改,解密过程将失败,因为身份验证标签不匹配。

3. jwe 示例

考虑一个场景,我们想要加密消息“hello, world!”使用 jwe。这是一个简化的细分:

磁力开创
磁力开创

快手推出的一站式AI视频生产平台

下载
  • 受保护的标头 : {"alg":"rsa-oaep","enc":"a256gcm"}
  • 加密密钥 : base64url(加密(与接收者公钥的对称密钥))
  • 初始化向量(iv):base64url(随机生成的iv)
  • 密文 : base64url(用对称密钥加密("hello, world!"))
  • 身份验证标签:base64url(gcm标签)

最终的 jwe 可能看起来像这样:

eyjhbgcioijsu0ett0ffucisimvuyyi6ikeyntzhq00ifq.
g_he3ppliss9c60_wfq-vp_mq1bu00z7xg.
48v1_alb6us04u3b.
5eym8mytxoxcblykhjbtkmmi.
xfbomyuzodetzdvtifvskq

4. jwe 如何运作?

jwe 的工作原理是结合使用公钥加密(用于加密对称密钥)和对称加密(用于加密实际负载)。该过程的工作原理如下:

密钥生成和管理

  • 发送者和接收者就公钥加密标准(例如 rsa 或椭圆曲线)达成一致。
  • 发送者生成一个随机对称密钥来加密消息。
  • 然后使用接收者的公钥对对称密钥进行加密。

加密过程

  • 发送者创建指定加密算法的 jwe 标头。
  • 有效负载(数据)使用对称密钥和初始化向量 (iv) 进行加密。
  • 对称密钥使用接收者的公钥进行加密。
  • 生成的组件被连接起来形成最终的 jwe。

解密过程

  • 接收者使用他们的私钥来解密加密的对称密钥。
  • 解密后的对称密钥将用于解密密文。
  • 接收者使用身份验证标签验证数据的完整性。

5. jwe的优缺点

5.1 优点

  • 保密性:提供端到端加密,确保数据隐私。
  • 互操作性:跨不同系统和平台兼容。
  • 完整性和安全性:确保数据免遭篡改。
  • 支持多个收件人:允许使用不同的密钥将数据加密到多个收件人。

5.2 缺点

  • 复杂性:加密和解密的过程可能很复杂且容易出错。
  • 性能开销:加密/解密过程会增加计算开销。
  • 更大的有效负载大小:由于加密元数据,jwe 有效负载比纯数据或 jwt 更大。

6. 如何用 java 创建 jwe

创建 jwe 涉及选择支持 jwe 标准的库。 java 中最流行的库之一是 nimbus jose jwt。下面是一个简单的示例,演示如何创建 jwe:

设置依赖关系

如果您使用 maven,请将以下依赖项添加到 pom.xml:


    com.nimbusds
    nimbus-jose-jwt
    9.22

创建并加密 jwe

这是一个 java 代码片段,演示了 jwe 的创建:

import com.nimbusds.jose.*;
import com.nimbusds.jose.crypto.*;
import com.nimbusds.jose.jwk.*;
import com.nimbusds.jose.jwk.gen.*;
import com.nimbusds.jwt.*;

public class jweexample {
    public static void main(string[] args) throws exception {
        // generate an rsa key pair
        rsakey rsajwk = new rsakeygenerator(2048).keyid("123").generate();
        rsakey rsapublicjwk = rsajwk.topublicjwk();

        // create the jwe header
        jweheader header = new jweheader(jwealgorithm.rsa_oaep_256, encryptionmethod.a256gcm);

        // set the payload
        payload payload = new payload("hello, world!");

        // create the jwe object
        jweobject jweobject = new jweobject(header, payload);

        // encrypt the jwe with the recipient's rsa public key
        jweobject.encrypt(new rsaencrypter(rsapublicjwk));

        // output jwe string
        string jwestring = jweobject.serialize();
        system.out.println("encrypted jwe: " + jwestring);

        // decrypt the jwe with the recipient's rsa private key
        jweobject = jweobject.parse(jwestring);
        jweobject.decrypt(new rsadecrypter(rsajwk));

        // output the decrypted payload
        system.out.println("decrypted payload: " + jweobject.getpayload().tostring());
    }
}

代码说明

  • 密钥生成 :生成 rsa 密钥对来加密和解密 jwe。
  • header 和 payload : header 指定加密算法,payload 包含要加密的数据。
  • 加密:rsaencrypter 用于加密有效负载。
  • 解密:rsadecrypter 将有效负载解密回其原始形式。

结果

运行上面的代码将生成一个加密的jwe字符串,然后将其解密回原始消息:

Decrypted Payload: Hello, World!

七、结论

json web 加密 (jwe) 是现代 web 应用程序中安全数据传输的重要工具。了解其结构、工作原理及其优缺点将帮助您就何时以及如何在应用程序中使用它做出明智的决定。如果您有任何疑问或需要进一步说明,请随时在下面发表评论!

阅读更多帖子:了解 jwe:结构、操作、优点、缺点以及如何创建一个

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
json数据格式
json数据格式

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

418

2023.08.07

json是什么
json是什么

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

535

2023.08.23

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

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

311

2023.10.13

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

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

77

2025.09.10

Java Maven专题
Java Maven专题

本专题聚焦 Java 主流构建工具 Maven 的学习与应用,系统讲解项目结构、依赖管理、插件使用、生命周期与多模块项目配置。通过企业管理系统、Web 应用与微服务项目实战,帮助学员全面掌握 Maven 在 Java 项目构建与团队协作中的核心技能。

0

2025.09.15

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1898

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2091

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1060

2024.11.28

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

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

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