[BJDCTF2020]easy

20 篇文章 0 订阅

[BJDCTF2020]easy

Start

开局看到这个:

int __cdecl main(int argc, const char **argv, const char **envp)
{
  __time32_t Time; // [esp+10h] [ebp-3F0h] BYREF
  struct tm *v5; // [esp+3FCh] [ebp-4h]

  __main();
  time(&Time);
  v5 = localtime(&Time);
  puts("Can you find me?\n");
  system("pause");
  return 0;
}

运行,啥都没有:
在这里插入图片描述
IDA中找了一圈,发现:

int ques()
{
  int v0; // edx
  int result; // eax
  int v2[50]; // [esp+20h] [ebp-128h] BYREF
  int v3; // [esp+E8h] [ebp-60h]
  int v4[10]; // [esp+ECh] [ebp-5Ch]
  int j; // [esp+114h] [ebp-34h]
  __int64 v6; // [esp+118h] [ebp-30h]
  int v7; // [esp+124h] [ebp-24h]
  int v8; // [esp+128h] [ebp-20h]
  int i; // [esp+12Ch] [ebp-1Ch]

  v3 = 2147122737;
  v4[0] = 140540;
  v4[1] = -2008399303;
  v4[2] = 141956;
  v4[3] = 139457077;
  v4[4] = 262023;
  v4[5] = -2008923597;
  v4[6] = 143749;
  v4[7] = 2118271985;
  v4[8] = 143868;
  for ( i = 0; i <= 4; ++i )
  {
    memset(v2, 0, sizeof(v2));
    v8 = 0;
    v7 = 0;
    v0 = v4[2 * i];
    LODWORD(v6) = *(&v3 + 2 * i);
    HIDWORD(v6) = v0;
    while ( v6 > 0 )
    {
      v2[v8++] = v6 % 2;
      v6 /= 2LL;
    }
    for ( j = 50; j >= 0; --j )
    {
      if ( v2[j] )
      {
        if ( v2[j] == 1 )
        {
          putchar('*');
          ++v7;
        }
      }
      else
      {
        putchar(32);
        ++v7;
      }
      if ( !(v7 % 5) )
        putchar(32);
    }
    result = putchar(10);
  }
  return result;
}

并且:
在这里插入图片描述
基本可以猜测这个就是能够解出flag的函数了,大概分析了一下,发现这个函数中不断的打印*以及并且总共应该是打印了五行的内容,猜测应该是打印出字母或者可能是一条迷宫直接放到VS中,打印看看。
直接复制会出现LODWORD和HIDWORD未定义的问题,原因是这两个类型是IDA中自定义的类型,位于IDA/plugins/defs.h中,所以把这个头文件导入即可
在这里插入图片描述
打印,可以看到前面三个字母为HAC,后面不知道为啥打印出问题了,不过也可以肯定这里就是通过这个函数打印出flag在这里插入图片描述
将程序放入x32dbg中,这里由于程序正常的执行流程并未调用到那个函数,所以需要将EIP指到函数的起始位置,那么需要先找到函数的首地址,这里还是比较简单,没有开ASLR,所以直接通过IDA找然后到x32dbg找对应的即可:
在这里插入图片描述
在这里插入图片描述
修改EIP为00401520:
在这里插入图片描述
直接运行得到结果:
在这里插入图片描述

HACKIT4FUN

End

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值