返回顶部
首页 > 资讯 > 后端开发 > Python >11行Python代码实现解密摩斯密码
  • 492
分享到

11行Python代码实现解密摩斯密码

2024-04-02 19:04:59 492人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

目录1、引言2、代码示例2.1摩尔斯电码科普2.2 加密2.3 解密3、总结1、引言 小屌丝:鱼哥,快来求助求助! 小鱼:嗯? 啥事,让你这么慌慌张张的? 小屌丝:刚刚我女神给我发古

1、引言

小屌丝:鱼哥,快来求助求助!

小鱼:嗯? 啥事,让你这么慌慌张张的?

小屌丝:刚刚我女神给我发古来这一段符号,我不知道啥意思,能不能帮我翻译一下?

小鱼:啥符号?

小屌丝:这个"… …-- --… —… …— … …-- —… —… -----"

小鱼:这… 这不是摩斯密码吗,你女神啥时候这么厉害了?

小屌丝:鱼哥,别管那么多了,快看看能不能翻译出啥意思,万一是我的女神要找我压马路呢?

小鱼:话说,我也不是名侦探… 这,有点难为我了。

小屌丝:啥条件都行,只要你能翻译出来。

小鱼:嗯~ 那我试试。

2、代码示例

2.1摩尔斯电码科普

在进行密码破解前,小鱼先来科普一下摩尔斯电码的姿势 知识。

1、起源:

摩尔斯电码( 又译为摩斯密码,英语:Morse code)是一种时通时断的信号代码,通过不同的排列顺序来表达不同的英文字母、数字和标点符号。是由美国人艾尔菲德·维尔与萨缪尔·摩尔斯在1836年发明。

2、组成

摩尔斯电码是一种早期的数码化通信形式,它依靠一系列的点和划来传递编码信息,它的代码包括五种:

  • 点( · ):1 (读 “滴” dit ,时间占据1t )
  • 划(—):111 (读 “嗒” dah ,时间占据3t )
  • 字符内部的停顿(在点和划之间):0 (时间占据1t )
  • 字符间停顿:000 ( 时间占据3t )
  • 单词间的停顿:0000000 ( 时间占据7t )

点的长度(也就是上面的时间长度t)决定了发报的速度。

3、对照表

接下来,我们就进入今天的最重要的环境,摩斯密码的加密与解密。

2.2 加密

一、思路

实现的步骤总共分三步:

第一步:把冰箱门打开

搞错了,重来

第一步:把对照表内容放到字典里;

第二步:加密时将明文拆分;

第三步:从字典取出对应的密码组合在一起;

二、代码示例

# -*- coding:utf-8 -*-
# @Time   : 2024-04-12
# @Author : carl_DJ

#对照表内容放入字典中
Dict_MorseCode = {
                   'A': '.-', 'B': '-...', 'C': '-.-.', 'D': '-..', 'E': '.',
                   'F': '..-.', 'G': '--.', 'H': '....', 'I': '..', 'J': '.---', 'K': '-.-',
                   'L': '.-..', 'M': '--', 'N': '-.', 'O': '---', 'P': '.--.', 'Q': '--.-',
                   'R': '.-.', 'S': '...', 'T': '-', 'U': '..-', 'V': '...-', 'W': '.--',
                   'X': '-..-', 'Y': '-.--', 'Z': '--..',
                   '1': '.----', '2': '..---', '3': '...--', '4': '....-', '5': '.....', '6': '-....',
                   '7': '--...', '8': '---..', '9': '----.', '0': '-----',
                   ', ': '--..--', '.': '.-.-.-', '?': '..--..', '/': '-..-.', '-': '-....-',
                   '(': '-.--.', ')': '-.--.-'
                   }
#加密
def encrypt(message):
    cipher = ''
    for code in message:
        if code != ' ':
            # 查字典并添加对应的摩斯密码
            # 用空格分隔不同字符的摩斯密码
            cipher += Dict_MorseCode[code] + ' '
        else:
            # 1个空格表示不同的字符
            # 2表示不同的词
            cipher += ' '
    return cipher


message = "53782 53880"
result = encrypt(message)
print(f'加密后的摩斯密码:{result}')

三、输出结果:

加密后的摩斯密码:..... ...-- --... ---.. ..---  ..... ...-- ---.. ---.. ----- 

2.3 解密

一、思路

思路与加密一样的,都是分三步:

第一步:把对照表内容放到字典里;

第二步:解密时通过密文去对照表找对应的明文;

第三步:拼接起来;

二、代码示例

# -*- coding:utf-8 -*-
# @Time   : 2024-04-12
# @Author : carl_DJ

#对照表内容放入字典中
Dict_MorseCode = {
                   'A': '.-', 'B': '-...', 'C': '-.-.', 'D': '-..', 'E': '.',
                   'F': '..-.', 'G': '--.', 'H': '....', 'I': '..', 'J': '.---', 'K': '-.-',
                   'L': '.-..', 'M': '--', 'N': '-.', 'O': '---', 'P': '.--.', 'Q': '--.-',
                   'R': '.-.', 'S': '...', 'T': '-', 'U': '..-', 'V': '...-', 'W': '.--',
                   'X': '-..-', 'Y': '-.--', 'Z': '--..',
                   '1': '.----', '2': '..---', '3': '...--', '4': '....-', '5': '.....', '6': '-....',
                   '7': '--...', '8': '---..', '9': '----.', '0': '-----',
                   ', ': '--..--', '.': '.-.-.-', '?': '..--..', '/': '-..-.', '-': '-....-',
                   '(': '-.--.', ')': '-.--.-'
                   }
#解密,就是将字符串从摩斯解密为英文的函数
def decrypt(message):
    # 在末尾添加额外空间以访问最后一个摩斯密码
    message += ' '
    decipher = ''
    citext = ''
    global i
    for code in message:
        # 检查空间
        if code != ' ':
            i = 0
            # 在空格的情况下
            citext += code
        # 在空间的情况下
        else:
            # 如果 i = 1 表示一个新字符
            i += 1
            # 如果 i = 2 表示一个新单词
            if i == 2:
                # 添加空格来分隔单词
                decipher += ' '
            else:
                # 使用它们的值访问密钥(加密的反向)
                decipher += list(Dict_MorseCode .keys())[list(Dict_MorseCode .values()).index(citext)]
                citext = ''
    return decipher

message = "..... ...-- --... ---.. ..---  ..... ...-- ---.. ---.. -----"
result = decrypt(message)
print(f'解密后的明文:{result}')

三、输出结果:

解密后的明文:53782 53880

小鱼:我擦~~ 小屌丝,你这可以啊。

小屌丝:啥情况,这不是一串数字,我也不懂啊

小鱼:你这是钢铁直男吧,这么明显的,你还不懂??

小屌丝:鱼哥,别绕弯子了,赶紧告诉我吧,是不是女神想我给她买好吃的了?

小鱼:唉~ ~ 真不明白,这么漂亮的妹子,想啥不行,非得想你…

小屌丝:此话当真,那我赶紧去哦。

小鱼:哎~ 你咋溜得这么快,我还没说完呢。

3、总结

看到这里,今天的分享就到这里了。

是不是觉得,摩斯密码也没有那么难嘛。

就是几行代码的事,太easy了。

以后追女神,是不是又有新套路了…

到此这篇关于11行python代码实现解密摩斯密码的文章就介绍到这了,更多相关Python解密摩斯密码内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 11行Python代码实现解密摩斯密码

本文链接: https://lsjlt.com/news/117367.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 11行Python代码实现解密摩斯密码
    目录1、引言2、代码示例2.1摩尔斯电码科普2.2 加密2.3 解密3、总结1、引言 小屌丝:鱼哥,快来求助求助! 小鱼:嗯? 啥事,让你这么慌慌张张的? 小屌丝:刚刚我女神给我发古...
    99+
    2024-04-02
  • 利用Python破解摩斯密码
    目录摩尔斯电码Python实现摩斯密码对照表加密解密测试完整代码总结在电影《无间道》中,刘建明(刘德华饰)作为黑帮的卧底在一次行动中发现了警察的卧底陈永仁(梁朝伟饰)与黄警督(黄秋生...
    99+
    2024-04-02
  • 如何利用Python破解摩斯密码
    这篇文章将为大家详细讲解有关如何利用Python破解摩斯密码,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。摩尔斯电码摩斯密码的定义如下:摩尔斯电码( 又译为摩斯密码,英语:Morse code)是一种时通...
    99+
    2023-06-29
  • Python制作摩斯密码翻译器
    目录分析摩斯密码对照表实现代码结果 分析 摩斯密码是一种将文本信息作为一系列通断的音调、灯光或咔嗒声传输的方法,无需特殊设备,熟记的小伙伴即可直接翻译。它以电报发明者Samuel F...
    99+
    2024-04-02
  • 2.leetcode唯一的摩斯密码
    1.题目International Morse Code defines a standard encoding where each letter is mapped to a series of dots and dashe...
    99+
    2023-01-31
    摩斯 密码 leetcode
  • 使用 Python 从音频中提取摩斯密码
    本人并非专业人士,在部分专业名词的表述上可能会出现错误,敬请谅解 前段时间在 BugKu 做题时碰到了这么一题 铁子,来一道 - Bugku CTF (WriteUp 可见同学的博客 【BugK...
    99+
    2023-10-23
    python 音视频 开发语言 笔记
  • Java Apache Kafka 的摩斯密码:解密分布式消息的奥秘
    ...
    99+
    2024-04-02
  • python实现凯撒密码加密解密的示例代码
    凯撒加密就是通过将字母移动一定的位数来实现加密和解密。明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移,被替换成密文。例如,当偏移量是2的时候,所有的字母B将被替换...
    99+
    2024-04-02
  • Python:实现密码加密解密(含完整源码)
    Python:实现密码加密解密(含完整源码) 密码加密是保护用户隐私的一种有效手段。本文将讲解如何使用Python编写一个简单的密码加密解密程序,并提供完整源代码。 步骤一:安装依赖库 我们需要使用到...
    99+
    2023-09-11
    python 开发语言
  • python密码加密与解密的实现
    目录一、对称加密1.1 安装第三方库 - PyCrypto1.2 加密实现二、非对称加密三、摘要算法3.1 md5加密3.2 sha1加密3.3 sha256加密3.4 sha384...
    99+
    2023-02-07
    python 密码加密 python 密码解密
  • python实现希尔密码加密的示例代码
    目录原理实现原理 希尔密码是运用基本矩阵论原理的替换密码,由Lester S. Hill在1929年发明。 每个字母当作26进制数字:A=0, B=1, C=2… 一串字母当成n维向量,跟一个n×n的矩阵相乘,再将得...
    99+
    2022-06-02
    python 希尔密码加密 python 希尔密码
  • Python移位密码、仿射变换解密实例代码
    目录前言一、移位密码二、仿射变换三、全部代码总结前言 这个代码是很久之前的,已经忘记具体的思路了,你可以结合此文章来了解两个加密方式的内容。 前两个步骤是对应加密方式的函数,第三个步...
    99+
    2024-04-02
  • 利用20行Python代码实现加密通信
    目录一、引言二、加密技术三、普通锁:简单的对称加密四、不可篡改的指纹:哈希函数五、矛与盾:非对称加密六、真言:数字签名七、总结一、引言 网络上充满了窃听,我们的信息很容易被不怀好意的...
    99+
    2024-04-02
  • python如何实现凯撒密码加密解密
    这篇文章主要介绍了python如何实现凯撒密码加密解密的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇python如何实现凯撒密码加密解密文章都会有所收获,下面我们一起来看看吧。凯撒加密就是通过将字母移动一定的位...
    99+
    2023-07-02
  • Python编程密码学文件加密与解密代码解析
    目录本章要点1 纯文本文件2 使用置换密码加密文件的源代码transpositionFileCipher.py3 运行置换密码加密文件程序的样例4 文件操作4.1 打开文件4.2 数...
    99+
    2024-04-02
  • android md5加密与rsa加解密实现代码
    代码如下: import java.io.UnsupportedEncodingException; import java.security.MessageDigest; ...
    99+
    2022-06-06
    加密 rsa md5加密 Android
  • python密码学一次性密码的实现
    目录一次性密码密码为什么它是坚不可摧的?加密解密一次性密码密码的实现安装代码输出一次性密码密码 一次性密码密码是一种Vignere密码,包括以下功能; 这是一个牢不可破的密码.密钥与...
    99+
    2024-04-02
  • python密码学文件解密实现教程
    目录代码输出在本章中,我们将讨论使用Python解密加密文件.请注意,对于解密过程,我们将遵循相同的过程,但不是指定输出路径,而是关注输入路径或加密的必要文件. 代码 以下是使用Py...
    99+
    2024-04-02
  • python密码学简单替代密码解密及测试教程
    目录简单替代密码示例输出简单替换密码测试输出简单替换密码解密代码简单替代密码 简单替换密码是最常用的密码,包括为每个密文文本字符替换每个纯文本字符的算法.在这个过程中,与凯撒密码算法...
    99+
    2024-04-02
  • python密码学RSA密码解密教程
    目录授权身份验证RSA密码解密本章是前一章的延续,我们使用RSA算法逐步实现加密,并详细讨论它. 用于解密密文的函数是as跟随 : def decrypt(ciphertext, p...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作