其他分享
首页 > 其他分享> > 【转】对称加密和分组加密中的四种模式(ECB、CBC、CFB、OFB)

【转】对称加密和分组加密中的四种模式(ECB、CBC、CFB、OFB)

作者:互联网

版权声明:本文为作者原创,如需转载,请注明出处
https://blog.csdn.net/weixin_42940826
注:以下图片来自于《图解密码学》,这本书讲的更全面细致,建议阅读,在我资源库中有此书,还有使用go语言具体实现和解释此书中的各种加密算法的文档,有需要的可以自习前往免费下载

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

一图全览五种分组模式

常用分组模式全览

五种模式详解

1. ECB - Electronic Code Book, 电子密码本模式

ECB模式图解


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


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


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


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

总结

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

Q:何时需要填充,何时不需要填充?
A:观察分组模式的图示可以看出,加密后再进行异或操作的不需要填充,而先进行异或操作再加密的则需要填充,这是因为异或操作需要两个相同长度的数据,一一对比计算!


代码实现

篇幅有限,我在这篇帖子用以上分组模式实现了AES、DES、3DES的加密解密(go语言),轻戳了解。
CBC模式实现DES和3DES加密解密
CTR模式实现AES加密解密

标签:OFB,CBC,加密,填充,模式,明文,分组,密文
来源: https://blog.csdn.net/sinolover/article/details/112307395