对称加密算法常用的五种分组模式(ECB/CBC/CFB/OFB/CTR)

Q:为什么需要分组模式?
A:明文的长度不固定,而分组密码只能处理特定长度的一块数据,这就需要对分组密码的算法进行迭代,以便将一段很长的明文全部加密,而迭代的方法就是分组的模式。

一图全览五种分组模式

常用分组模式全览
五种模式详解
1. ECB - Electronic Code Book, 电子密码本模式

特点: 简单, 效率高, 密文有规律, 容易被破解
最后一个明文分组必须要填充
des/3des -> 最后一个分组填充满8字节
aes -> 最后一个分组填充满16字节
不需要初始化向量

ECB模式图解

2. CBC - Cipher Block Chaining, 密码块链模式(推荐使用)

特点: 密文没有规律, 经常使用的加密方式
最后一个明文分组需要填充
des/3des -> 最后一个分组填充满8字节
aes -> 最后一个分组填充满16字节
需要一个初始化向量 - 一个数组
数组的长度: 与明文分组相等
数据来源: 负责加密的人的提供的
加解密使用的初始化向量值必须相同

CBC模式的加密

3. CFB - Cipher FeedBack, 密文反馈模式

特点: 密文没有规律, 明文分组是和一个数据流进行的按位异或操作, 最终生成了密文
需要一个初始化向量 - 一个数组
数组的长度: 与明文分组相等
数据来源: 负责加密的人的提供的
加解密使用的初始化向量值必须相同
不需要填充

CFB模式加密

4. OFB - Output-Feedback, 输出反馈模式

特点: 密文没有规律, 明文分组是和一个数据流进行的按位异或操作, 最终生成了密文
需要一个初始化向量 - 一个数组
数组的长度: 与明文分组相等
数据来源: 负责加密的人的提供的
加解密使用的初始化向量值必须相同
不需要填充

OFB分组模式

5. CTR - CounTeR, 计数器模式(重点,推荐使用)

特点: 密文没有规律, 明文分组是和一个数据流进行的按位异或操作, 最终生成了密文
不需要初始化向量
go接口中的iv可以理解为随机数种子, iv的长度 == 明文分组的长度
不需要填充
这里我们有必要给出CTR模式额解密流程,因为CTR模式的解密和加密是一模一样的过程,在程序实现中也是可逆的,具体程序在文章实现底部有链接

CTR分组模式
CTR解密流程
通过对比发现CTR加密即解密,解密即加密,且各分组之间是独立的,可以并发完成,效率高。
总结
以上五种分组模式中,ECB模式很容易被破解,如今已经很少再使用,其余四种分组模式各有千秋。
但极力推荐CBC模式和CTR模式,尤其是CTR模式,不需要填充,代码实现起来很方便。而且加密和解密的方法是一样的,并且可以实现并发分组,效率高,安全性也有保障

 

  • 5
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
这些都是对称加密算法分组模式,用于将明文分组加密,以保证加密算法的安全性。以下是每个模式的简要介绍: 1. ECB模式(Electronic Codebook):将明文分成若干块,每个块独立加密,最终合并成密文。但是,ECB模式存在一个重大问题,如果明文中出现重复的块,那么对应的密文也会完全相同,这就使得攻击者有可能根据这种规律进行破解。 2. CBC模式(Cipher Block Chaining):与ECB模式不同,CBC模式需要用到一个初始向量(IV),每个块的加密都依赖于前一个块的密文和当前块的明文。因此,CBC模式中每个块的加密都受到了前一个块的影响,这使得相同的明文块在加密后也会变成不同的密文块,提高了加密的安全性。 3. CFB模式(Cipher Feedback):CFB模式是将明文分成若干块,并且将上一块的密文作为加密下一块明文的密钥。这种方式产生了一个“反馈”机制,使得每个明文块都会影响到加密后的结果。但是,CFB模式会导致误差传递,即加密误差在每个分组中被传递到下一个分组中。 4. OFB模式(Output Feedback):OFB模式CFB模式非常类似,但是它使用了一个非线性函数来产生伪随机数流(PRNG),而不是使用上一块的密文。这种方式消除了误差传递问题,并且可以提供更好的安全性。 5. CTR模式(Counter):CTR模式将一个计数器与密钥相结合,产生伪随机数流来加密明文。这种方式与OFB模式类似,但是CTR模式具有更好的并行性和更高的速度。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值