Java 11 – ChaCha20-Poly1305加密示例

本文向您展示如何使用RFC 7539中定义的ChaCha20-Poly1305算法对消息进行加密和解密。

PS ChaCha20-Poly1305加密算法可从Java 11获得。

1.常见问题

一些常见问题:

1.1什么是ChaCha20-Poly1305
ChaCha20-Poly1305表示使用Poly1305身份验证器以AEAD模式运行的ChaCha20 (加密和解密算法)。

1.2什么是AE或AEAD?
认证加密(AE)和带有关联数据的认证加密(AEAD)是一种加密消息并一起认证加密的形式。

1.3认证加密意味着什么?
确保没有人修改密文(加密的消息),它的工作方式类似于验证文件的SHA或MD5哈希。 Poly1305生成一个MAC (消息验证码)(128位,16字节),并将其附加到ChaCha20密文(加密的文本)中。 在解密过程中,该算法检查MAC以确保没有人修改密文。

1.4 ChaCha20-Poly1305如何工作?
ChaCha20加密使用密钥和IV(初始化值,nonce)将明文加密为等长的密文。 Poly1305生成一个MAC(消息认证码)并将其附加到密文中。 最后,密文和明文的长度不同。

1.5我可以将同一随机数重用于不同的密钥吗?
不可以,每个加密的随机数和密钥都必​​须是唯一的,否则密文会妥协!

注意

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值