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

本文解析了一项涉及算法破解的挑战,通过使用IDA分析Linux64位文件,并采用C语言重新实现关键逻辑,展示了如何理解并复制算法过程。代码实例详细说明了字符数组操作和异或运算。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

点明主题,这道题涉及到算法。
在这里插入图片描述
使用exeinfo了解是linux64位文件,使用IDA打开。

在这里插入图片描述
主要逻辑部分在于

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

调到sub_4007F0()就算赢。
在这里插入图片描述
OK,既然是C语言写的算法,推荐C语言来解。
这里的IDA出现的_DWORD、可以不用管,十分底层的姿势,你就认为是普通unsign int就可以了。

_BYTE可以用unsign char来代替。

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

贴上代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#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,结束。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值