[密码学]DES

先声明两个基本概念

代换(substitution),用别的元素代替当前元素。des的s-box遵循这一设计。

abc-->def

置换(permutation),只改变元素的排列顺序。des的p-box遵循这一设计。

abc-->bac

DES最核心的算法就是feistel结构的16轮加密 。

该结构以工作在IBM的德国密码研究员Horst Feistel的名字命名。其中涉及轮函数F,和每一轮的子密钥K。

F函数内部:

依次经过带<扩展属性>的p-box(会产生重复的元素),(与每一轮对应的子密钥K)异或,带<压缩属性>s-box,正常的p-box。

子密钥K的生成方法:

标准的DES要求密钥为64bit,但是每8位中最后一位为奇偶校验位,不参与真正的加密。

pc--permutation choice,也是带<压缩属性>的p-box

经过pc1盒----舍弃奇偶校验位(共8bit,剩下56bit)并置换。

记56bit的左28bit为C0,右28bit为D0。C0,D0进行循环左移,左移的位数根据当前的加密轮次不同。

再经过pc2盒,即可生成当前轮次的子密钥。

相关推荐
衍生星球8 小时前
【网络安全】对称密码体制
网络·安全·网络安全·密码学·对称密码
chirrupy_hamal20 小时前
为什么 ECB 模式不安全
密码学
粉车绿衣搞笑网工女2 天前
密码学---easy_hash
算法·密码学·哈希算法
nina_LeXin2 天前
Mina protocol - 体验教程
web3·区块链·密码学·零知识证明
辉哥的编程道路4 天前
基于OpenSSL的密码管理系统-应用密码学课程报告
计算机·密码学·同等学力申硕
粉车绿衣搞笑网工女5 天前
密码学---常见的其他密码
网络安全·密码学
CyberSecurity_zhang5 天前
密码学基础--ECDSA算法入门
密码学·椭圆曲线·ecdsa
不会代码的小徐5 天前
CTF常见编码及加解密(超全)第二篇
网络安全·密码学·预编码
chirrupy_hamal6 天前
加密
密码学
EthanXone1967 天前
【学习笔记】SSL密码套件之哈希
密码学·哈希算法·ssl·mac·密码套件·poly1305·aead