攻防世界Misc入门题之掀桌子
继续开启全栈梦想之逆向之旅~
这题是攻防世界Misc入门题之掀桌子
题目是一串16进制数,因为只有0~f,不是base64,直接扔到十六进制转字符串:
好的,不知道转了啥东西,看来还要再处理一下,查了查资料,说是要转十进制后再减128,因为超出ASCII可打印字符边界了,自己想了想,十六进制转字符串不还是对着ASCII表来转换的吗,如果我直接两两一组的十六进制减0x80不就行了吗?
想象很美好,写脚本的时候我发现两个十六进制互减总会显示str和Int型的报错,因为我的两个十六进制是从题目中截取出来的,它的确是字符串,而我自己要减的0x80是数字,搞了一会还是搞蹦了,而且0x只是为了在运算符中让计算机自动转换为十进制而已,转换中不用带0x前缀,也就是说我后面还要把0x前缀去掉才能用python2的str.decode(‘hex’)解码,关键是如果前面减0x80成功了后面还要再转换成字符串类型,因为这里是str.decode。
好吧,我放弃了,老老实实用十进制把:
附上python2脚本:
key1="c8e9aca0c6f2e5f3e8c4efe7a1a0d4e8e5a0e6ece1e7a0e9f3baa0e8eafae3f9e4eafae2eae4e3eaebfaebe3f5e7e9f3e4e3e8eaf9eaf3e2e4e6f2"
key2=[]
flag=""
for i in range(0,len(key1),2):
s='0x'+key1[i]+key1[i+1]
key2.append(int(s,16))
print key2
for i in key2:
flag+=chr(i-128)
print flag
好的,学到了新技巧,遇到十六进制串的确是往字符串转换去想,如果转换不了就试着减掉ASCII可打印字符边界128再转。