攻防世界-逆向game
当所有灯都亮起来的时候,flag就出现了
查找字符串,找到flag,CTRL+X直接定位到这句话所在的函数。
按F5反汇编,得到伪代码
像这种非常短的伪代码,就需要仔细研读循环,发现v2经过循环可以得出一个数,那么!我们来分析一下下面这个代码
for (i = 0; i < 56; ++i)
{
*(& v51 + i) ^= *(& v108 + i);
*(& v51 + i) ^= 0x13u;
}
&51是取地址,然后*是得到那个地址对应的值。
i=0,v51^=v108,这句话的意思就是
v51=v51^v108
i=1,
v52=v52^v109
v52=v52^0x13
0x13u=0x13,u是无符号数,0x是十六进制,0x13=19
python中整个列表,用于一会进行循环计算
把需要的后半部分v51-v107放到word里面,按alt选中左半边,然后按delete删除,就可以的到纯数字
然后把分号;替换成逗号,(因为一会在列表里面也是用逗号分隔)
然后想把他们放在一行里面,因为现在他们是分开的几行,用下面这个替换
效果拔群,再用文字工具删除多余的空格
进入python编写脚本
同样把后面的108到最后也做如上操作形成列表
把C语言翻译成python语言,python
a=[123,32,18,98,119,108,65,41,124,80,125,38,124,111,74,49,83,108,94,108,84,6,96,83,44,121,104,110,32,95,117,101,99,123,127,119,96,48,107,71,92,29,81,107,90,85,64,12,43,76,86,13,114,1,117,126,0]
b=[18,64,98,5,2,4,6,3,6,48,49,65,32,12,48,65,31,78,62,32,49,32,1,57,96,3,21,9,4,62,3,5,4,1,2,3,44,65,78,32,16,97,54,16,44,52,32,64,89,45,32,65,15,34,18,16,0]
for i in range(57):
a[i]=a[i]^b[i]
a[i]=a[i]^19
print(a[i])
因为输出的都是数字,需要再输出的时候转换成char,因为flagf都是字符串,然后这个程序运行的结果我们就得到了flag字符串。
print(chr(a[i]))
python的print自动换行,然后我们不要让他换行,就输出一行flag
学好python!!!!