国际赛IrisCTF在前几天举办,遇到了一道有意思的题目,特来总结。
题目
附件如下: 📎babyrevjohnson.tar
解题过程
关键main函数分析如下:
将check提取出来,我们方便分析
其实到这里已经可以得到结果了,国外的题目确实很讲究趣味性,用颜色和食物作为导向,引导一步一步分析
笔者使用静态分析的方法,一步一步跟踪
C++
对应的输入值地址如下:
我们将颜色color数组用x系列表示,将食物用food数组y系列表示
化简如下:
思路1:简单粗暴的爆破,但不是学习的目的,因此并不采用
思路2:锻炼写脚本能力,使用z3解题可以锻炼写脚本的能力,因此采用
Python
得到结果
Python
其实有经验的师傅发现了,这是有多解的,因为没有为约束变量添加范围约束
帮助网安学习,全套资料S信免费领取:
① 网安学习成长路径思维导图
② 60+网安经典常用工具包
③ 100+SRC分析报告
④ 150+网安攻防实战技术电子书
⑤ 最权威CISSP 认证考试指南+题库
⑥ 超1800页CTF实战技巧手册
⑦ 最新网安大厂面试题合集(含答案)
⑧ APP客户端安全检测指南(安卓+IOS)
改进之后的代码如下:
Python
发现x1和x3重复了,因此还要添加值不重复约束
最终得到正确的结果
Python
成功:
x1 = 1
x2 = 4
x3 = 3
x4 = 2
y1 = 4
y2 = 2
y3 = 3
y4 = 1
x1-x4= 1 4 3 2
y1-y4= 4 2 3 1
按照这样的顺序输入即可:
得到了flag
irisctf{m0r3_th4n_0n3_l0g1c_puzzl3_h3r3}
总结
题目并不是很难,没有复杂的ollvm混淆也没有复杂的加密。但是却一步一步引导我们去学习和总结。z3解题的过程中,会有很多误解,然后经过自己的思考总结,发现了漏掉的东西,再进行补充,最终写出正确的脚本。
国外的题还是很值得学习的,不单单为了出题而出题。这就是逻辑运算在z3的运用以及如何增加约束,让z3求解出我们需要的key