密码编码学与网络安全(3):对称密码之分组密码和数据加密标准

本文详细介绍了分组密码的原理,特别是Feistel密码结构及其在DES数据加密标准中的应用。讨论了Feistel密码的混淆和扩散概念,以及DES的加解密过程和安全性分析。通过对迭代轮数、轮函数和密钥扩展算法的探讨,揭示了分组密码设计的关键要素。
摘要由CSDN通过智能技术生成

流密码与分组密码

流密码每次加密数据流的一位或一个字节,如果密钥流是随机的,除非获得密钥流,否则这个密码是不可破的。然而,密钥流必须提前以某种独立、安全的信道提供给双方。如果待传递的数据流量很大,这就带来了一个不可逾越的障碍。相应地,出于实用的原因,位流必须以算法程序的方式实现,从而双方都可以生产具有密码学意义的位流。
在这里插入图片描述
分组密码是将一个明文分组作为整体加密并且通常得到的是与明文等长的密文分组。典型的分组大小是64位或128位。与流密码一样,两个用户要共享以恶对称加密密钥。

传统分组密码结构

Feistel密码原理

分组密码作用在n位明文分组上,而产生n位密文分组。共有2n个不同的明文分组,且由于加密是可逆的(即可以解密),每一个明文分组将唯一对应一个密文分组。这样的变换称为可逆变换,或非奇异变换。下图表示了n=2时的非奇异变换和奇异变换。
在这里插入图片描述
n=4时,4位的输入有16种可能的输入状态,每一种被代替密码映射成16种可能输出状态中的唯一一个,每一个表示4位的密文输出。这是分组密码的最一般形式,能用来定义明文之间的任意可逆变换。Feistel称这种密码为理想分组密码,因为它允许生产最大数量的加密映射来映射明文分组。然而,从现实和运行角度看,采用大规模分组的任何可逆代替密码(即理想分组密码)时不可行的。因为对于这样的变换,映射本身就是密钥。考虑到这些困难,Feistel指出我们所需的是对理想分组密码体制(分组长度n较大)的一种近似体制而已。
Feistel建议使用乘积密码的概念来逼近理想分组密码。乘积密码是指依次使用两个或两个以上基本密码,所得结果的密码强度将强于所有单个密码的强度。这种方法的本质是开发一个分组密码࿰

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

二流人物

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值