BUUCTF逆向—luck_guy

1. DIE 查壳,64 位无壳文件

2. 直接拖入64位IDA,找到main函数,按F5反汇编看代码:

要求用户输入一个lucky number,并将这个值存储在v4变量中,再调用了一个patch_me函数对v4进行了处理,随后打印结束语,程序结束。因此可以知道patch_me函数是一个关键。

c3866fb50f9244ea81e54ed667576cc2.png

3. 进入 patch_me,一眼找到关键字 get_flag,点进去看一下。

8a35876c0708425393d92c72e3ae9e60.png

4. ①.Case2 和 case3 只是一个打印函数。
    ②.strcat 是连接字符串函数,所以 case4 是对 s 赋值并将 s 与 f2 进行拼接。
    ③.case5 是对 f2 进行处理:j 为奇数,f2 减 2;j 为偶数,f2 减 1。
    ④.Case1 是要得到 flag,首先memset函数先对 s 进行初始化,s 变成了一个空数组,所以之后的 strcat 函数相当于直接把 f1 复制到了 s 里,再之后的 strcat 函数将 s 与 f2 连接相当于 f1 与 f2 连接,最终打印出来的 flag 就是 f1 加上 f2。
s=0x7F666F6067756369LL,按r键将它转换为字符就是“\x7Ffo`guci”,这里要注意是小端序存储!所以要把字符顺序反过来,就是“icug`of\x7F”

 d24adece7cf8444f93c6fb6c3c7a80e0.png

5. 进入 f1,发现一半答案{do_not_。进入 f2 发现啥都没有,那就写个脚本自己找f2。

b01a72a5f64b43149b62bcb79e642eca.png e6a92686d4fb449b8f3327995d9bb493.png

6. 写脚本运行得到f2的内容:hate_me},从而得到最终的flag。

#include <iostream>
using namespace std;
int main()
{
    char f2[] = "icug`of\x7F";

    for (int j = 0; j < 8; ++j)
    {
        if ( j % 2 == 1 )
            f2[j]-=2;
        else
            f2[j]--;
    }

    printf("%s",f2);

    return 0;
}
  • 14
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值