【CTF-crypto练习】摩斯电码变形题python实现(easy_crypto)

摩尔斯电码(又译为摩斯密码,Morse code)是一种时通时断的信号代码,通过不同的排列顺序来表达不同的英文字母、数字和标点符号。它发明于1837年,发明者有争议,是美国人塞缪尔·莫尔斯或者艾尔菲德·维尔。 摩尔斯电码是一种早期的数字化通信形式,但是它不同于现代只使用零和一两种状态的二进制代码,它的代码包括五种: 点、划、点和划之间的停顿、每个字符之间短的停顿、每个词之间中等的停顿以及句子之间长的停顿。

一般的摩斯密码是由“. - ”以及“ ”组成,然而也有部分题目是有“0 1”构成,此类题目又称莫斯密码变形题。

下面列举一道题。此题出自bugku

题目:

分析:密文串由01以及空格组成。且每段的长度不一样。

解法:首先使用python将1->"-",0->".",然后再按照解莫斯密码的方式来解。

1.1->"-",0->"."

#-*- coding utf-8 -*

path = '/home/clown/crypto/easy30'
fd = open(path)
s = fd.readlines()[0][:-1]
t = s.replace('0', '.')
t = t.replace('1', '-')

print s
print t

2.通过在线摩斯解密工具进行解密,即可得出答案。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值