Enigma算法图解

一 什么是Enigma

Enigma是德国人阿瑟.谢尔比乌斯于20世纪初发明的一种能够进行加密和解密操作的机器。Enigma这个名字在德语中是"谜"的意思。谢尔比乌斯使用能够转动的圆盘和电路,创造出人类手工无法实现的高强度密码。在刚刚发明之际,Enigma被用于商业领域,后来到了纳粹时期,德国国防军采用了Enigma,并将其改良后用于军事用途。

二 用Enigma进行加密通信的流程

Enigma是一种用于加解密的机器,我们把他理解为密码世界的算法,只不过这个算法是由物理实体实现,而不是软件实现。

发送者和接收者各自拥有一台Enigma。发送者用Enigma将明文加密,将生成的密文通过无线电发送给接收者。接收者将接收到的密文用自己的Enigma解密,得到明文。

发送者和接收者会事先收到一份叫国防军密码本的册子,它记录了发送者和接收者所使用的每日密码,发送者和接收者需要分别按册子的指示来设置Enigma。这里提到的每日密码相对于密码算法需要使用的密钥。

三 Enigma的构造

Enigma的构造还是相对复杂的,涉及物理学、电学等知识,它充当密码学中算法的作用。

这里给出它的物理构造图

关于它的构造和实现原理,在此不深究,有兴趣的读者可上网搜索。

四 Enigma的加密

发送者将一个包含5个字母的德语单词nacht(夜晚)进行加密并发送。

第1步:设置Enigma

按照每日密码,设置Enigma,具体来说,就是在接线板上接线,并将3个转子进行排列。

第2步:加密通信密码

发送者想出3个字母,并将其加密。这3个字母称为通信密码。通信密码也是Enigma完成的。假设发送者选择通信密码为psv,那么就要在键盘上输入两次通信密码,也就是输入psvpsv这6个字母,输入完后,发送者可得到psvpsv的密文ATCDVT。

第3步:重新设置Enigma

通信密码中的3个字母实际代表了3个转子的初始位置。每个转子的上面都印有字母,根据字母来设置转子的初始位置。通信密码psv就表示需要将转子1、2、3分别转到p、s、v所对应的位置。

第4步:加密信息

键盘输入nacht5个字母,并记录下所对应的5个字母(KXNWP)。

第5步:拼接

发送者将ATCDVT和KXNWP进行拼接,拼接成ATCDVTKXNWP,然后通过无线电发送出去。

五 每日密码和通信密码

每日密码:每日密码是用来加密通信密码的。这种密钥被称为密钥加密密钥。

通信密码:通信密码来加密消息。

六 避免通信错误

两次输入通信密码psv,是为了避免通信错误,接收者解密后,如果通信密码不是3个字母重复两次这样的形式,就说明通信错误。

七 Enigma解密

第1步:分解

将收到的ATCDVTKXNWP分解为ATCDVT和KXNWP两部分。

第2步:设置Enigma

按照每日密码,设置Enigma,具体来说,就是在接线板上接线,并将3个转子进行排列。这一步和发送者操作相同。

第3步:解密通信密码

对ATCDVT进行解密,键盘输入对应字母,输出psvpsv,psv重复两次,接收者判断通信过程没有错误。

第4步:重新设置Enigma

根据通信密码psv,重新设置Enigma,这一步和发送者的第三步相同。

第5步:解密消息

对KXNWP进行解密,键盘输入KXNWP,输出明文natcht5个字母。

八 Enigma的弱点

1 Enigma可以在每次输入时,通过3个转子的旋转来改变电路。然而,在加密通信密码这一重要步骤,实际只有一个转子1会旋转,这是弱点之一。

2 将通信密码连续输入两次并加密也是一个弱点。

3 通信密码是人为选的的也是一个弱点。

4 必须派发国防军密码本也是一个弱点。

  • 6
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PyInstaller是一个用于将Python程序打包成可执行文件的工具,可以将Python代码和依赖的库打包为一个独立的可执行文件,方便在没有Python解释器的环境下运行程序。你可以使用以下命令来使用PyInstaller生成可执行文件:`pyinstaller -D -w xxx.py`,其中`-D`选项生成一个文件夹,里面是多文件模式,启动快,`-w`选项表示生成的可执行文件没有命令行窗口。 Enigma Virtual Box是一个免费的打包工具,可以将PyInstaller生成的多文件可执行文件打包为一个单个的可执行文件。你可以先使用PyInstaller生成多文件可执行文件,然后使用Enigma Virtual Box打包成一个可执行文件。以下是打包exe文件的步骤: 1. 使用命令`pyinstaller -D -w xxx.py`生成多文件可执行文件(xxx.py为项目主程序)。 2. 下载并安装Enigma Virtual Box。 3. 使用Enigma Virtual Box打包生成的多文件可执行文件,使其成为一个单个的可执行文件。 在打包之前,你可以先运行测试一下PyInstaller生成的exe文件是否可以正常运行。如果出现缺少dll库文件等问题,可以将缺少的文件拷贝到PyInstaller生成的目录下。当测试运行正常后,再使用Enigma Virtual Box对最终的exe文件进行打包。 关于Python镜像源的选择,你可以根据自己的需求选择合适的镜像源,如豆瓣、阿里、清华等。这些镜像源可以提供更快速的包下载速度,你可以在pip安装时指定镜像源,例如`pip install packagename -i http://pypi.douban.com/simple/`。 总结来说,PyInstaller是用于将Python程序打包成可执行文件的工具,Enigma Virtual Box是用于将PyInstaller生成的多文件可执行文件打包成一个单个可执行文件的工具。你可以先使用PyInstaller生成多文件可执行文件,然后使用Enigma Virtual Box打包成一个单个的可执行文件。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [通过pyinstaller和Enigma Virtual Box打包python程序,提升启动速度,避免了tkinter窗口使用图标等资源文件...](https://blog.csdn.net/qq_25921925/article/details/103949384)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Python开发环境(Visual Studio Code、Anaconda、PyInstaller、Enigma Virtual Box)](https://blog.csdn.net/u013420428/article/details/132376664)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值