今天学弟问了一个CTF题,是关于二进制字符文件转二进制文件的问题。
自己用了一个struct库解出来了,代码是这样的:
import struct
f = open("num.txt","r")
fout = open("res.txt","ab+")
data = f.read()
for i in range(0,len(data),16):
try:
ds = struct.pack("c",chr(int(data[i:i+8],2)))
fout.write(ds)
ds = struct.pack("c",chr(int(data[i+8:i+16],2)))
fout.seek(i) #转换字节序
fout.write(ds)
fout.seek(i + 16)
except Exception:
pass
fout.close()
f.close()
上面的python脚本运行结果会输出一个zip文件,解压后得到一张图片,图里藏着一个base64编码,两次解码后得到flag:
为啥这个jpg文件里面有地方可以写这种东西。。用010套了个jpg模板,结果如下:
查了一个dalao的博客,发现这个字段是用来填充说明字段的(看说明这个图生成的时候用的是PS:)):
好的,认为这题圆满解决,没想到队里的菊苣一行代码解决了问题。。。。。。又学到了新姿势orz
python -c "print format(int(open('num.txt').read(),2),'x').decode('hex')" > 1.zip
这里用了一个decode函数,将一个16进制字符串转换为16进制数,重定向输出到zip文件中。
查了一下decode函数,发现decode还可以解码字符串为这些编码:
以及另一个菊苣给出的不写代码解法:
首先将二进制字符串文件ctrl + c一下,之后打开010editor:
就出现了压缩包。。。