码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 密码学引论 | DES


    文章目录

          • DES算法
            • 1 算法流程
            • 2 算法细节
              • (1)子密钥的产生
              • (2)初始置换 I P IP IP
              • (3)加密函数
              • (4)逆初始置换 I P − 1 IP^{-1} IP−1
          • 例题


    DES算法
    1 算法流程
    1. 64位密钥经子密钥产生算法产生出16个子密钥:K1,K2…,K16,分别供第一次,第二次,…,第十六次加密迭代利用。

    2. 64位明文首先经过初始置换IP,将数据打乱重新排列并分为左右两半。左边32位构成L0,右边32位构成R0。

    3. 由加密函数f实现子密钥K1对R0的加密,结果为32位数据组f(R0,K1)。f(R0,K1)再与L0模2相加,又得到一个32位的数据组L0⊕f(R0,K1)。以L0⊕f(R0,K1)作为第二次加密迭代的R1,以R0作为第二次加密迭代的L1。至此,第一次加密迭代结束。

    4. 第二次加密迭代至第十六次加密迭代分别用子密钥K2,…,K16进行,其过程与第一次加密迭代相同。

    5. 第十六次加密迭代结束后,产生一个64位的数据组。以其左边32位作为R16,以其右边32位作为L16,两者合并再经过逆初始置换,将数据重新排列,得到64位密文。至此加密过程全部结束。
      在这里插入图片描述


    2 算法细节
    (1)子密钥的产生

    64位密钥经过置换选择1、循环左移、置换选择2等变换,产生出16个48位长的子密钥。

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述
    在这里插入图片描述


    (2)初始置换 I P IP IP

    将64位明文打乱重排,并分为两半。
    在这里插入图片描述
    在这里插入图片描述


    (3)加密函数

    在第i次迭代加密中选择运算E对32位的Ri-1的各位进行选择和排列,产生一个48位的结果。此结果与子密钥Ki模2相加,然后送入代替函数S。代替函数组由8个代替函数(S盒子)组成,每个S盒子有6位输入,产生4位输出。8个S盒子的输出合并,结果得到一个32位的数据组。此数据组在经过置换运算P,将其各位打乱。置换运算P的输出便是加密函数的输出f(Ri-1,Ki)。

    在这里插入图片描述
    在这里插入图片描述

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述


    (4)逆初始置换 I P − 1 IP^{-1} IP−1

    将第16次加密迭代的结果打乱重排,形成64位密文。
    在这里插入图片描述
    在这里插入图片描述


    例题

    考了差分的计算

  • 相关阅读:
    [Hello World] 二分查找笔记
    Docker 搭建 Minio 容器
    网络安全 day6 --- 抓包技术&HTTPS协议&小程序&PC应用&WEB&转发联动
    生成对抗网络(GAN)
    【scikit-learn基础】--『分类模型评估』之评估报告
    总结一下前端常见面试题(一)
    (论文阅读)TiDB:一款基于Raft的HTAP数据库
    常用排序算法原理分析及Java代码实现
    安装zip扩展(PHP)
    数据安全是竞争优势,公司如何优先考虑信息安全和合规性
  • 原文地址:https://blog.csdn.net/weixin_52116519/article/details/127830783
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号