ctfshow MISC 滑天下之大稽

本文介绍了一种从下载的压缩包中提取并解密Flag的方法,首先通过010或winhex查看未加密图片,从中获取一串特殊字符,接着利用这些字符解密文本,最终成功揭示Flag。

下载下来压缩包,得到一张未加密的图片,和加密的文本。
把图片放到010或者winhex里面查看得到一串奇怪的字符
在这里插入图片描述
然后复制下来去解密flag.txt
就出来flag啦

从参考内容得知,ctfshow misc34题与图片文件结构有关,解题涉及爆破图片的宽高。下面是具体的解题思路和代码示例: 解题思路:推测是图片的宽高信息有误,导致图片无法正常显示,需要通过遍历不同的宽度值(高度可能暂未涉及变更或者默认不变),依次生成新的图片文件,再尝试打开这些新生成的图片,用以找到能正常显示的图片所对应的正确宽度值。 代码示例如下,其功能是依次设置宽度值为901到1199,并生成对应的图片文件: ```python import zlib import struct filename = "E:\misc入门\misc入门题目\misc题目(文件结构)\misc34.png" with open(filename, 'rb') as f: all_b = f.read() #w = all_b[16:20] #h = all_b[20:24] for i in range(901,1200): name = str(i) + ".png" f1 = open(name,"wb") im = all_b[:16]+struct.pack('>i',i)+all_b[20:] f1.write(im) f1.close() ``` 另外,也有类似思路的代码,不过文件路径使用的是相对路径: ```python import zlib import struct filename = "misc34.png" with open(filename, 'rb') as f: all_b = f.read() #w = all_b[16:20] #h = all_b[20:24] for i in range(901,1200): name = str(i) + ".png" f1 = open(name,"wb") im = all_b[:16]+struct.pack('>i',i)+all_b[20:] f1.write(im) f1.close() ``` 上述代码的关键在于通过`struct.pack('>i', i)`来修改图片数据中的宽度信息,然后将修改后的数据写入新的文件,不断尝试不同的宽度值,直到找到能正常打开的图片,该图片对应的宽度即为正确的宽度值[^3][^5]。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yu22x

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值