StevenPZChan
StevenPZChan
5 min read

Categories

Tags

进入正式的挑战了!


第一题的地址在map.html

  • map.jpg
  • 网页标题是What about making trans?
  • 题目内容是everybody thinks twice before solving this.和一堆乱码

    g fmnc wms bgblr rpylqjyrc gr zw fylb. rfyrq ufyr amknsrcpq ypc dmp. bmgle gr gl zw fylb gq glcddgagclr ylb rfyr’q ufw rfgq rcvr gq qm jmle. sqgle qrpgle.kyicrpylq() gq pcamkkclbcb. lmu ynnjw ml rfc spj.

  • 剩下的是通用tips:要用到各种提示、尽可能挖掘数据、不要被剧透、blabla

乍一看很无头绪,事实上题目内容就这么多,尽可能都利用起来。
答案肯定就藏在这堆乱码里面。
结合网页标题和图片,先尝试做几个字符转换:

encoded_str = "g fmnc wms bgblr rpylqjyrc gr zw fylb. rfyrq ufyr amknsrcpq ypc \
dmp. bmgle gr gl zw fylb gq glcddgagclr ylb rfyr'q ufw rfgq rcvr gq qm jmle. \
sqgle qrpgle.kyicrpylq() gq pcamkkclbcb. lmu ynnjw ml rfc spj."

mapping_dict = {}
mapping_dict['k'] = 'm'
mapping_dict['o'] = 'q'
mapping_dict['e'] = 'g'

decoded_str = ''.join(mapping_dict.get(c, c) for c in encoded_str)
print(decoded_str)
g fmnc wms bgblr rpylqjyrc gr zw fylb. rfyrq ufyr ammnsrcpq ypc dmp. bmglg gr gl zw fylb gq glcddgagclr ylb rfyr'q ufw rfgq rcvr gq qm jmlg. sqglg qrpglg.myicrpylq() gq pcammmclbcb. lmu ynnjw ml rfc spj.

呃,还是一堆乱码。
结合这个transmap一想,K到M是往后两个字母,O到Q是往后两个字母,E到G也是往后两个字母,那么是不是这堆乱码全部做这样的转换呢? 结果如下:

mapping_dict = {}
for a in range(ord('a'), ord('z') + 1):
    mapping_dict[chr(a)] = chr(a + 2)
    
decoded_str = ''.join(mapping_dict.get(c, c) for c in encoded_str)
print(decoded_str)
i hope you didnt tr{nsl{te it |y h{nd. th{ts wh{t computers {re for. doing it in |y h{nd is inefficient {nd th{t's why this text is so long. using string.m{ketr{ns() is recommended. now {pply on the url.

有点像那么回事了!
不过有些字符不太对,仔细一看,应该是y和z要循环转成a和b。

这里科普一下恺撒密码:
在密码学中,恺撒密码(英语:Caesar cipher),或称恺撒加密、恺撒变换、变换加密,是一种最简单且最广为人知的加密技术。它是一种替换加密的技术,明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。例如,当偏移量是3的时候,所有的字母A将被替换成D,B变成E,以此类推。这个加密方法是以罗马共和时期恺撒的名字命名的,当年恺撒曾用此方法与其将军们进行联系。

From baike.baidu
mapping_dict = {}
for a in range(ord('a'), ord('y')):
    mapping_dict[chr(a)] = chr(a + 2)
mapping_dict['y'] = 'a'
mapping_dict['z'] = 'b'
    
decoded_str = ''.join(mapping_dict.get(c, c) for c in encoded_str)
print(decoded_str)
i hope you didnt translate it by hand. thats what computers are for. doing it in by hand is inefficient and that's why this text is so long. using string.maketrans() is recommended. now apply on the url.

翻译一下就是告诉我们不要手动一个一个字母地翻译,要使用计算机。这也是计算机的用处。还推荐我们使用string.maketrans()这个函数。
我们完整更新下代码:(其中string是旧版本python的类,现在我们用str就可以了)

intab = 'abcdefghijklmnopqrstuvwxyz'
outtab = 'cdefghijklmnopqrstuvwxyzab'
trans = str.maketrans(intab, outtab)
decoded_str = encoded_str.translate(trans)
print(decoded_str)
print('map'.translate(trans))
i hope you didnt translate it by hand. thats what computers are for. doing it in by hand is inefficient and that's why this text is so long. using string.maketrans() is recommended. now apply on the url.
ocr

maketrans()函数确实简洁不少,返回的对象作为translate()函数的参数,还可以重用,美滋滋。
上面代码已经完成了题目信息的最后一句now apply on the url不知道有没人尝试'url'.translate(trans)2333,将结果输入到URL地址上ocr.html,页面打开了,果然是下一题。

总结:题目还不难,也回忆起了小时候玩的密码游戏。python内置的一些函数很不错的,要多用用。

本题代码地址1_map.ipynb