脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|shell|

服务器之家 - 脚本之家 - Python - python密码学一次性密码的实现

python密码学一次性密码的实现

2023-02-16 11:56菜鸟教程 Python

这篇文章主要为大家介绍了python密码学一次性密码的实现,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

一次性密码密码

一次性密码密码是一种Vignere密码,包括以下功能;

  • 这是一个牢不可破的密码.
  • 密钥与加密邮件的长度完全相同.
  • 密钥由随机符号组成.
  • 顾名思义,密钥仅使用一次,并且从不再用于任何其他消息加密.

由于这个原因,加密邮件很容易受到密码分析者的攻击.用于一次性密码密码的密钥称为pad,因为它打印在纸垫上.

 

为什么它是坚不可摧的?

由于以下功能,密钥是牢不可破的;

  • 密钥只要是给定的消息.
  • 密钥是真正随机的,特别是自动生成的.
  • 按模10/26/2计算的密钥和纯文本.
  • 每个密钥应使用一次,并由发送方和接收方销毁.
  • 应该有两个密钥副本:一个带发件人,另一个带接收者.

加密

要加密字母,用户需要在明文下面写一个密钥.明文字母位于顶部,密钥字母位于左侧.两个字母之间的横截面是纯文本.它在下面的示例中描述 :

python密码学一次性密码的实现

解密

要解密一封信,用户会取左边的关键字母,并在该行中找到密文字母.纯文本字母位于列的顶部,用户可以在其中找到密文字母.

 

一次性密码密码的实现

Python包含一个用于one-time-pad密码实现的hacky实现模块.包名称称为One-Time-Pad,其中包括一个命令行加密工具,该工具使用类似于一次性密码密码算法的加密机制.

安装

您可以使用以下命令安装此模块 :

 pip install onetimepad

如果您希望从命令行使用它,请运行以下命令 :

 onetimepad

python密码学一次性密码的实现

代码

以下代码有助于生成一次性密码密码;

import onetimepad
cipher = onetimepad.encrypt('One Time Cipher', 'random')
print("Cipher text is ")
print(cipher)
print("Plain text is ")
msg = onetimepad.decrypt(cipher, 'random')
print(msg)

输出

运行上面和下面给出的代码时,您可以观察到以下输出;

python密码学一次性密码的实现

注意: 如果密钥的长度小于消息的长度(纯文本),则加密的消息很容易破解.

在任何情况下,密钥不一定是随机的,这使得一次性密码密码作为一种有价值的工具.

以上就是python密码学一次性密码的实现的详细内容,更多关于python一次性密码的资料请关注服务器之家其它相关文章!

原文链接:https://www.it1352.com/OnLineTutorial/cryptography_with_python/cryptography_with_python_implementation_of_one_time_pad_cipher.html

延伸 · 阅读

精彩推荐