二、从零开始学逆向之XCTF-logmein

点明主题,这道题涉及到算法。
二、从零开始学逆向之XCTF-logmein_第1张图片
使用exeinfo了解是linux64位文件,使用IDA打开。

二、从零开始学逆向之XCTF-logmein_第2张图片
主要逻辑部分在于

v4 = (unsigned int)(char)(*((_BYTE *)&v8 + i % v7) ^ v9[i]);

调到sub_4007F0()就算赢。
二、从零开始学逆向之XCTF-logmein_第3张图片
OK,既然是C语言写的算法,推荐C语言来解。
这里的IDA出现的_DWORD、可以不用管,十分底层的姿势,你就认为是普通unsign int就可以了。

_BYTE可以用unsign char来代替。

写代码这回事,多写就能懂它的意思了,就和追女生一样,不多聊天,你能了解啥?直接直奔主题?想清楚了,三年起步。

贴上代码

#include 
#include 
#include 
#define BYTE unsigned char
int main(int argc, char* argv[]) {
 unsigned int i;
 char v8[18] = ":\"AL_RT^L*.?+6/46";
 long v7 = 28537194573619560;
 int v6 = 7;
 char s[18] = "";
 for (i = 0; i < strlen(v8); ++i) {
 s[i] = (char)(*((BYTE*)&v7 + i % v6)^v8[i]);
 }
 printf("%s\n", s);
 return 0;
}

在这里插入图片描述
OK,结束。

你可能感兴趣的:(逆向学习)