0x00 前言
越呆着心越慌,索性做道题压压惊。
0x01 正文
不一样?有多不一样?是骡子是马牵出来遛遛。
还是先查壳,32位程序,C++编写,Balabalabala……,打开32位IDA。
看到一串奇怪的代码“*11110100001010000101111#”,前面有个start,程序就是从这开始的,那么,在哪里结束呢?
OK,从答案逆向分析。和“#”对比之后,输出flag;esp指向1的时候退出。结合一下前面的字符串。
第4位的时候对齐,那这串字符串的排列应该就是这个样子的,顺便回来分析一下这个程序。
通过前面分析,不碰到1,一直走到#,那路线应该是222441144222。回到题目,这题的flag不带"flag{}",那最终的flag应该就是flag{222441144222}。
0x03 总结
这道题还是挺有意思的,万万没想到的是题目是一个迷宫。通过从结果往开始分析,理清了思路,就是找条件的时候确实有点费劲,想了好久。最近总是很焦虑,做做题好像能好一点,也许是菜的原因,提升技术才是根本。