对称加密DES(ECB/CBC/CFB/OFB/CTR)

对称加密

DES(Data Encryption Standard)

DES密钥长度是56bit,从规格上来说,DES的密钥长度是64bit,但由于每隔7bit会设置一个错误检查的bit,因此实质上其密钥长度是56bit。
DES是以64bit的明文为一个单位进行加密,以64个bit进行分组,因此DES每次加密只能加密64bit的数据,当加密明文比较长,则进行迭代。所以当进行加密时对明文拆分每8个字节(64bit)一组,通过加密算法进行加密。

3DES加密

加密 -> 解密 -> 加密 可以兼容DES,3DES密钥为24个字节(128bit)
在这里插入图片描述
在这里插入图片描述

注意:如果密钥1和密钥3使用相同的密钥,而密钥2使用不同的密钥(也就是只使用两个DES密钥),这种三重DES就称为DES-EDE2。
EDE表示的是加密(Encryption) -->解密(Decryption)–>加密(Encryption)这个流程。
密钥1、密钥2、密钥3全部使用不同的比特序列的三重DES称为DES-EDE3。

AES (Advanced Encryption Standard)

相对DES安全
分组长度为128bit(16字节)
密钥长度可以以32比特为单位在128比特到256比特的范围内进行选择(不过在AES的规格中,密钥长度只有128、192和256比特三种)。
和DES—样,AES算法也是由多个轮所构成的,下图展示了每一轮的大致计算步骤。DES使用Feistel网络作为其基本结构,而AES没有使用Feistel网络,而是使用了SPN Rijndael的输人分组为128比特,也就是16字节。首先,需要逐个字节地对16字节的输入数据进行SubBytes处理。所谓SubBytes,就是以每个字节的值(0~255中的任意值)为索引,从一张拥有256个值的替换表(S-Box)中查找出对应值的处理,也是说,将一个1字节的值替换成另一个1字节的值。

  • 3
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值