【密码学】一文读懂Padding模式

本文详细介绍了密码学中的Padding模式,包括NoPadding、PKCS5/PKCS7、X923Padding、ISO10126Padding、ISO7816-4Padding、TBCPadding和PKCS1Padding。这些模式用于在加密时确保明文长度符合分组要求。例如,AES加密通常要求明文为块大小的倍数,Padding模式则通过特定方式填充不足的字节。文章还提供了各Padding模式的特点和区别,并给出了代码实现。
摘要由CSDN通过智能技术生成

密码学番外篇 - Padding模式

Padding模式

在对于数据进行加密的时候,某些加密算法需要明文满足某些长度的要求,比如DES和AES等分组加密需要明文满足是分组的倍数,但是大多数情况下,明文恰好满足需求的概率是非常低的,在之前的实现中,我的实现均没有考虑不满足加密长度的情况,也就是我自己保证了我传入的内容就是满足需求的,本文将聊一聊在不满足的情况下如何进行Padding

NoPadding

顾名思义,这个就是不填充,也就是之前我采取的模式,这个要求原始数据必须就是满足分组要求的数据,不满足的时候,无法使用该模式。

NoPadding

PKCS5/PKCS7

填充至符合块大小的整数倍,填充值为填充数量数,PKCS5Padding的块大小应为8个字节,而PKCS7Padding的块大小可以在1~255的范围内。因为AES块的大小恰好为8个字节,因此对于AES的Padding来说,这两种方式是一样的。

PKCS5/PKCS7

X923Padding

填充至符合块大小的整数倍,填充值最后一个字节为填充的数量数,其他字节填0

X923Padding

ISO10126Padding

填充至符合块大小的整数倍,填充值最后一个字节为填充的数量数,其他字节填充随机字节。

ISO10126Padding

ISO7816-4Padding

填充至符合块大小的整数倍,填充值第一个字节为0x80,其他字节填0x00

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值