BUUCTF:https://buuoj.cn/challenges
题目描述:
得到的 flag 请包上 flag{} 提交。
密文:
下载附件解压,得到很多没有后缀的文件和一个ZIP压缩包。
data:image/s3,"s3://crabby-images/c15d8/c15d8af26348343aa8e484d50b0b93a246c3c391" alt=""
解题思路:
1、首先,查看ZIP压缩包,发现有密码,并且在压缩包的注释找到疑似被加密的压缩包密码,初步解密失败。
data:image/s3,"s3://crabby-images/55f76/55f760d2b4ea54892f12ce3d438bc07a5e21012c" alt=""
bash
GNATOMJVIQZUKNJXGRCTGNRTGI3EMNZTGNBTKRJWGI2UIMRRGNBDEQZWGI3DKMSFGNCDMRJTII3TMNBQGM4TERRTGEZTOMRXGQYDGOBWGI2DCNBY
查看其他的无后缀文件,在010 Editor中观察到jpg文件的文件头,猜测为jpg文件。
bash
JPEG (jpg) 文件头:FF D8 FF 文件尾:FF D9
data:image/s3,"s3://crabby-images/25b56/25b5678bb3fd6a6feb48156739aafcc305260c2c" alt=""
修改文件后缀为.jpg,发现是二维码的一部分,其他文件是一样的,共36个二维码碎片。
data:image/s3,"s3://crabby-images/2d6f9/2d6f9589e454da1053c46b419ab5906ff2059617" alt=""
2、二维码应该存在解开压缩包的线索。先将所有的无后缀文件改为.jpg文件,可以手动添加,也可以使用python脚本完成。
python
#coding=UTF-8
import os
path = 'D:\\CTF\\CTF_topic\\吹着贝斯扫二维码' # 需要添加后缀的文件路径
for i in os.listdir('D:\\CTF\\CTF_topic\\吹着贝斯扫二维码'):
if i == 'flag.zip':
continue
else:
oldname = os.path.join(path, i)
newname = os.path.join(path, i+'.jpg')
os.rename(oldname, newname)
然后,使用Ps软件将所有二维码碎片组合起来,恢复原有的二维码,跟玩拼图一样。(但是真的很慢)
data:image/s3,"s3://crabby-images/d3adf/d3adf6e9c4e22582f77e9a51ec508fd1a43e0787" alt=""
3、扫描二维码,得到加密字符串的加密顺序,如下:
data:image/s3,"s3://crabby-images/dbb3c/dbb3cce703e95d89d6ef393d1867b84dc527a89d" alt=""
加密顺序:base85 >> base64 >> base85 >> rot13 >> base16 >> base32
解密只需要按照加密顺序反转进行解密就可以啦
解密顺序:base32 >> base16 >> rot13 >> base85 >> base64 >> base85
bash
GNATOMJVIQZUKNJXGRCTGNRTGI3EMNZTGNBTKRJWGI2UIMRRGNBDEQZWGI3DKMSFGNCDMRJTII3TMNBQGM4TERRTGEZTOMRXGQYDGOBWGI2DCNBY
base32 https://the-x.cn/encodings/Base32.aspx
bash
3A715D3E574E36326F733C5E625D213B2C62652E3D6E3B7640392F3137274038624148
data:image/s3,"s3://crabby-images/762bf/762bf6c638c4536aa5a522c456d372f6d330ac05" alt=""
base16 https://www.qqxiuzi.cn/bianma/base.php?type=16
bash
:q]>WN62os<^b]!;,be.=n;v@9/17'@8bAH
data:image/s3,"s3://crabby-images/64335/64335acde9d71e8b4aa31c4a3ba14358b23e9090" alt=""
rot13 https://lzltool.cn/Tools/Rot13
bash
:d]>JA62bf<^o]!;,or.=a;i@9/17'@8oNU
data:image/s3,"s3://crabby-images/61046/61046acaa578b6250a45d15a162d7a8d0c6f6595" alt=""
base85 http://www.atoolbox.net/Tool.php?Id=934
bash
PCtvdWU4VFJnQUByYy4mK1lraTA=
data:image/s3,"s3://crabby-images/120c5/120c50cf111a7856d35d5ff87d09f81944da2c13" alt=""
base64 https://base64.supfree.net/
bash
<+oue8TRgA@rc.&+Yki0
data:image/s3,"s3://crabby-images/567f1/567f1b898cc17d301234dc299ec2654ceb8782cf" alt=""
base85 (解密需使用ASCII85编码标准)http://www.hiencode.com/base85.html
bash
ThisIsSecret!233
4、得到明文,使用它解压压缩包,得到flag.txt文件。
data:image/s3,"s3://crabby-images/edab2/edab2d93e5b860b24bd4034b7e2817cfb654e132" alt=""
flag:
bash
flag{Qr_Is_MeAn1nGfuL}