作者:ch4nge
时间:2020.12.20
题目资源下载
sorry 下载积分忘记改为0了,,,选择已经修改了
https://download.csdn.net/download/qq_25094483/13743845
今天的比赛,趁着热乎,写一篇writeup记录一下做出来的题目,比赛是针对萌新的,很友好,我只做了Crypto和Misc部分,幸运的是把这两类题目做完了,在这里分享一下思路,希望可以帮助CTF入门的小伙伴~
注意:一些编解码网站直接在超链接里面,蓝色字体就是。
比赛体验感一般,上午9点刚开始比赛,平台的比赛入口就没了~最后离结束十几分钟的时候排名也是疯狂掉哇QAQ
题目类型:编码
解题步骤:

得到F#S
命令:
python basecrack.py -b "F#S
Decoding as Base92: flag{you_very_good!!}
编码方式 Base92
$ git clone https://github.com/mufeedvh/basecrack.git
$ cd basecrack
$ pip install -r requirements.txt
$ python basecrack.py -h
$ python basecrack.py -b "F#S
题目类型:编码
解题步骤:
bhag{asb_zsz_vtsz_aszw}
得到一串接近答案的字符串
flek{ewf_dwd_zxwd_ewda},但是显然这不是正确答案,与密文字符串对比发现此字符前两个与密文字符串第3 4位字符加一起是flag
bhag{asb_zsz_vtsz_aszw}
flek{ewf_dwd_zxwd_ewda}
发现在密文字符的十进制为偶数的时候才进行移4位操作,奇数的时候不变
bh分别为98 104,加4之后是102 108,ag是奇数 103 123,不变,结果是flag
>>> chr(102)
'f'
>>> chr(108)
'l'
两个if判断用来区分大小写操作
# -*- coding: utf-8 -*-
c = 'bhag{asb_zsz_vtsz_aszw}'
yy = 4#移位4
d=''
for i in range(len(c)):
if c[i]>='a' and c[i]<='z' and ord(c[i])%2 == 0:
d=d+chr((ord(c[i])+yy-97)%26+97)
elif c[i]>='A' and c[i]<='Z' and ord(c[i])%2 == 0:
d=d+chr((ord(c[i])+yy-65)%26+65)
else:
d=d+c[i]
print(d)
d=''
flag{asf_dsd_zxsd_asdw}
第一次看到这么不可读的flag,你敢信这是答案
题目类型:编码
解题步骤:
二维码解码网站
\u0056\u0054\u004a\u0047\u0063\u0032\u0052\u0048\u0056\u006d\u0074\u0059\u004d\u0053\u0074\u006c\u0061\u0046\u0068\u006b\u0052\u0048\u0056\u0042\u004d\u0030\u0056\u0044\u004e\u0031\u0052\u006a\u0063\u006a\u0056\u0069\u0054\u0030\u0068\u004f\u0061\u0048\u0070\u0069\u0052\u0056\u0042\u0050\u0065\u006a\u0055\u0031\u0052\u0032\u0052\u0035\u004e\u0056\u004e\u0030\u0057\u006c\u0055\u0033\u0055\u006b\u0052\u0036\u0057\u0054\u0064\u0049\u005a\u006e\u0049\u0031\u0054\u0054\u0046\u004b\u0062\u0030\u0035\u0030\u0065\u0067\u006f\u0067
VTJGc2RHVmtYMStlaFhkRHVBM0VDN1RjcjViT0hOaHpiRVBPejU1R2R5NVN0WlU3UkR6WTdIZnI1TTFKb050egog
U2FsdGVkX1+ehXdDuA3EC7Tcr5bOHNhzbEPOz55Gdy5StZU7RDzY7Hfr5M1JoNtz
得到flag{2020jdbctfdasai}
题目类型:zip伪加密、base64编码、仿射密码
解题步骤:
此图没有提示.jpg
命令
binwalk -e m1.jpg
这个压缩包导入工具准备爆破的时候瞬间提示没有找到密码,那就是没有密码了
工具网上很好找,这里不添加了
命令:
java -jar ZipCenOp.jar r BC5D.zip
success 1 flag(s) found
工具修改的是原文件,没有生成新文件,直接解压得到1.txt
文件内容太长了,csdn粘贴不全,文章首部会附上题目文件
解码一下(注意base64编码在b’’里面),解码一次后发现结果还是base64编码。。。写一个脚本循环解码
import base64
b=''
while 1:
b = base64.b64decode(b)
b = str(b)[2:-1]
print(b)
yqjb{lha-drwohjw-ekf}
凯撒、简单替换密码、移位密码、仿射密码~就那几种,挨个试呗,得到解密方式是仿射密码
仿射密码破解 python3脚本
脚本在这里
https://blog.csdn.net/qq_25094483/article/details/111463214
flag{six-yuntian-hjq}
题目类型:图片数据隐藏
解题步骤:
pass:111111
flag{gogogo_xiaohuolong}
题目类型:CRC32碰撞
解题步骤:
0x555FA1A2, 0xE5C67F46, 0x6E957E45, 0x76D6A31A, 0x2B042586
环境python2
# -*- coding:utf-8 -*-
import datetime
import binascii
txt=''
def crack():
crcs = set([0x555FA1A2, 0xE5C67F46, 0x6E957E45, 0x76D6A31A, 0x2B042586])
for a in range(32,127):
for b in range(32,127):
for c in range(32,127):
for d in range(32,127):
txt = chr(a)+chr(b)+chr(c)+chr(d)
crc = binascii.crc32(txt)
if (crc & 0xFFFFFFFF) in crcs:
print txt
if __name__ == "__main__":
crack()
Mw==
YjEy
Z2Vu
aW9u
cG90
3 b12 gen ion pot
压缩包密码就是potiongenb123
flag{I_always_take_5_potion_when_i_g0_0ut}
题目类型:编程、图片修剪
解题步骤:
末尾看到信息
keyis7034735377307244
得到p4sSw0rD
在第一行尾部看到了jpg图片的文件头FF D8 FF E0
在文件末尾看到了jpg的文件尾部FF D9
把每一行的内容进行逆序排列一下就可以得到正确顺序的jpg文件的16进制了
python3环境
#!/usr/bin/python
# -*- coding: UTF-8 -*-
import re
re = []
my_open = open("./dx.txt", 'a')#以追加的方式进行写文件
f = open('./flag.txt'); #打开文件,进行读取内容
for line in f.readlines():
re = line.split(' ')
re=re[:-1]
re=re[::-1]
my_open.write(" ".join(re)+'\n')
my_open.close()
flag{you_get_1t}
题目类型:编码、zip密码爆破、c语言判断
解题步骤:
4位数字.zip
,使用ziperello
工具进行爆破得到密码9156
草帽一伙历经千辛万苦,终于找到了one piece,但是最终的宝箱面前却有一串密码(似乎还缺少一把钥匙),众人冥思苦想找不到答案,只能求助于你,你能帮助他们解开吗?
密码如下:
文明诚信民主文明友善平等文明友善平等文明诚信民主文明友善平等文明诚信民主文明诚信民主文明诚信民主平等友善平等和谐诚信自由和谐诚信自由文明友善平等文明诚信民主和谐友善爱国文明友善平等文明友善平等文明诚信民主文明诚信民主和谐友善爱国文明诚信民主文明友善平等文明友善平等文明友善平等文明友善平等文明友善平等和谐友善爱国文明诚信民主文明诚信民主文明诚信民主文明诚信民主文明友善平等文明友善平等文明诚信民主文明诚信民主和谐友善爱国文明友善平等文明友善平等文明友善平等文明友善平等文明友善平等文明友善平等文明诚信民主文明友善平等文明友善平等文明诚信民主和谐诚信自由文明诚信民主文明诚信民主文明友善平等文明诚信民主文明友善平等文明友善平等文明友善平等文明诚信民主文明友善平等文明友善平等文明友善平等文明诚信民主和谐友善爱国文明友善平等文明诚信民主文明友善平等文明诚信民主文明诚信民主文明诚信民主文明诚信民主文明诚信民主文明诚信民主文明诚信民主文明友善平等文明友善平等文明诚信民主文明友善平等和谐友善爱国文明友善平等文明友善平等文明诚信民主文明诚信民主文明友善平等文明诚信民主文明友善平等文明诚信民主文明友善平等文明诚信民主文明友善平等文明友善平等文明友善平等文明诚信民主文明诚信民主文明诚信民主和谐友善爱国文明友善平等文明诚信民主文明诚信民主文明诚信民主文明诚信民主文明友善平等文明友善平等文明诚信民主文明诚信民主文明诚信民主文明友善平等文明诚信民主文明诚信民主文明诚信民主文明友善平等文明友善平等文明友善平等文明友善平等和谐友善爱国文明友善平等文明诚信民主文明友善平等文明友善平等文明友善平等文明友善平等文明诚信民主文明诚信民主文明友善平等文明友善平等文明友善平等文明友善平等文明友善平等文明诚信民主文明友善平等文明友善平等文明友善平等文明诚信民主文明友善平等文明友善平等和谐诚信自由文明诚信民主文明诚信民主文明友善平等文明诚信民主文明诚信民主文明友善平等文明诚信民主文明诚信民主文明诚信民主文明友善平等文明友善平等文明诚信民主文明诚信民主文明友善平等文明友善平等文明友善平等文明友善平等文明诚信民主文明友善平等文明诚信民主文明友善平等文明友善平等和谐友善爱国文明诚信民主文明友善平等文明友善平等文明友善平等文明诚信民主文明友善平等文明友善平等文明诚信民主文明诚信民主文明诚信民主文明友善平等文明友善平等文明友善平等文明友善平等文明诚信民主文明友善平等文明诚信民主文明友善平等文明诚信民主文明友善平等文明诚信民主文明友善平等文明友善平等文明友善平等和谐友善爱国文明诚信民主文明友善平等文明诚信民主文明诚信民主文明诚信民主文明友善平等文明友善平等文明友善平等文明友善平等文明诚信民主文明友善平等文明诚信民主文明诚信民主文明诚信民主文明友善平等文明诚信民主文明友善平等文明友善平等文明友善平等文明诚信民主文明诚信民主文明友善平等文明友善平等文明诚信民主文明诚信民主文明友善平等和谐诚信自由文明友善平等文明友善平等文明友善平等文明诚信民主文明友善平等文明诚信民主文明友善平等文明友善平等文明友善平等文明诚信民主文明诚信民主文明诚信民主文明友善平等文明友善平等文明诚信民主文明友善平等文明友善平等文明诚信民主文明友善平等文明诚信民主文明诚信民主文明友善平等文明友善平等文明友善平等文明诚信民主文明友善平等文明友善平等文明友善平等和谐诚信自由文明友善平等文明友善平等文明诚信民主文明友善平等文明友善平等文明诚信民主文明诚信民主文明友善平等文明友善平等文明诚信民主文明诚信民主文明诚信民主文明诚信民主文明诚信民主文明友善平等文明友善平等文明友善平等文明诚信民主文明诚信民主文明诚信民主文明友善平等文明友善平等文明友善平等文明友善平等文明友善平等文明诚信民主文明友善平等文明友善平等文明友善平等文明诚信民主和谐诚信文明和谐友善公正和谐友善公正和谐友善公正和谐诚信文明和谐友善公正和谐诚信文明和谐友善公正和谐诚信文明和谐诚信文明和谐诚信文明和谐友善公正和谐诚信文明和谐诚信文明和谐诚信文明和谐诚信文明文明友善法治平等友善法治和谐诚信自由和谐友善爱国和谐诚信自由和谐友善爱国和谐诚信自由和谐诚信自由和谐诚信自由文明诚信民主文明诚信民主文明诚信民主文明诚信民主文明诚信民主文明诚信民主文明友善平等文明诚信自由和谐友善爱国文明友善法治文明友善法治文明友善法治文明诚信和谐文明友善爱国和谐友善公正文明诚信和谐文明友善法治文明友善法治文明友善法治文明诚信和谐文明友善爱国文明友善平等文明友善平等文明友善平等文明诚信自由和谐友善爱国和谐诚信自由文明友善法治文明诚信和谐文明诚信和谐文明友善法治文明诚信和谐文明友善爱国和谐诚信文明文明友善平等文明友善平等文明诚信民主文明友善平等文明友善爱国文明友善法治文明友善法治文明诚信自由和谐诚信文明文明友善平等文明诚信自由文明诚信和谐文明诚信和谐文明友善法治文明诚信和谐文明友善法治文明友善法治文明诚信和谐文明诚信自由和谐诚信自由文明诚信自由文明诚信和谐文明诚信和谐文明友善法治文明诚信和谐文明友善爱国文明诚信和谐文明诚信和谐文明友善法治文明诚信和谐文明诚信和谐文明诚信自由文明诚信和谐文明诚信自由文明诚信和谐文明诚信自由和谐诚信文明文明诚信自由和谐友善爱国文明友善平等文明诚信民主文明诚信民主文明诚信民主文明友善平等文明友善平等文明友善平等文明友善爱国和谐友善爱国文明诚信和谐文明诚信和谐文明诚信和谐文明友善法治文明友善法治文明诚信和谐文明诚信和谐文明诚信和谐文明诚信自由和谐诚信文明和谐友善公正文明友善爱国和谐诚信自由和谐友善爱国文明诚信民主文明诚信民主文明友善爱国和谐友善公正文明友善法治文明诚信和谐文明诚信和谐文明诚信和谐文明诚信自由文明诚信民主文明诚信民主文明诚信民主文明友善平等文明友善爱国和谐友善爱国文明诚信和谐文明诚信和谐文明友善爱国和谐友善公正和谐友善公正文明友善爱国和谐友善爱国文明友善平等文明诚信自由文明诚信民主文明友善平等文明诚信自由和谐诚信自由文明诚信民主文明诚信民主文明友善平等文明友善爱国文明友善法治文明友善法治文明友善法治文明诚信和谐文明友善爱国和谐诚信文明文明诚信民主文明诚信民主文明诚信自由和谐诚信文明文明诚信民主文明诚信民主文明诚信民主文明友善平等文明诚信自由和谐诚信自由和谐友善爱国文明诚信民主文明友善平等文明诚信民主文明诚信民主文明友善平等文明友善平等文明友善平等文明诚信民主文明诚信自由和谐友善公正和谐诚信文明和谐友善公正和谐友善公正和谐诚信文明和谐友善公正文明诚信民主文明友善爱国和谐诚信自由和谐诚信自由和谐友善爱国和谐诚信自由和谐诚信自由和谐友善爱国文明友善平等文明诚信民主文明诚信民主文明友善爱国
++++++++[>>++>++++>++++++>++++++++>++++++++++>++++++++++++>++++++++++++++>++++++++++++++++>++++++++++++++++++>++++++++++++++++++++>++++++++++++++++++++++>++++++++++++++++++++++++>++++++++++++++++++++++++++>++++++++++++++++++++++++++++>++++++++++++++++++++++++++++++<<<<<<<<<<<<<<<<-]>>>>>>>+++++++.>----.<-----.+++.>>-----.<++++.--.<+.-------.>.----.-----.-.-.<.>+++++++.>--------.<<.>>++.<----.++++.>--.<<.>+.++.>+++.----.<++.<++++.>>++++++++.<<<<<<+.>>>>>>+++.
得到
glbe{pnf_njedc_js_ufjs_kmvrocz!}
现在去看一下secret.c文件,分析出密钥
#include
#include
#include
int main(int argc, char* argv[]) {
unsigned int first, second, thirdly, fourthly;
if (first + 2 != 100)
{
printf("wrong!\n");
}
if (second * second != 9409)
{
printf("Made a mistake!\n");
}
if (thirdly / 7 == 14 && thirdly < 100)
{
printf("yes! You got it\n");
}
if (fourthly != 121)
{
printf("not this!\n");
}
int p[4] = {first,second,thirdly,fourthly};
int i;
printf("key:");
for ( i = 0; i < 4; i++)
{
printf("%c", p[i]);
}
printf("\n");
return 0;
}
得到答案
flag{one_piece_is_this_journey!}