BUUCTF Reverse 不一样的flag

BUUCTF Reverse 不一样的flag

一天一道CTF题目,能多不能少

题目提示:
BUUCTF Reverse 不一样的flag_第1张图片
下载文件用IDA打开(32),直接查看主函数:

int __cdecl main(int argc, const char **argv, const char **envp)
{
  char v3; // [esp+17h] [ebp-35h]
  int v4; // [esp+30h] [ebp-1Ch]
  int v5; // [esp+34h] [ebp-18h]
  signed int v6; // [esp+38h] [ebp-14h]
  int i; // [esp+3Ch] [ebp-10h]
  int v8; // [esp+40h] [ebp-Ch]

  __main();
  v4 = 0;
  v5 = 0;
  qmemcpy(&v3, _data_start__, 0x19u);
  while ( 1 )
  {
    puts("you can choose one action to execute");
    puts("1 up");
    puts("2 down");
    puts("3 left");
    printf("4 right\n:");
    scanf("%d", &v6);
    if ( v6 == 2 )
    {
      ++v4;
    }
    else if ( v6 > 2 )
    {
      if ( v6 == 3 )
      {
        --v5;
      }
      else
      {
        if ( v6 != 4 )
LABEL_13:
          exit(1);
        ++v5;
      }
    }
    else
    {
      if ( v6 != 1 )
        goto LABEL_13;
      --v4;
    }
    for ( i = 0; i <= 1; ++i )
    {
      if ( *(&v4 + i) < 0 || *(&v4 + i) > 4 )
        exit(1);
    }
    if ( *((_BYTE *)&v8 + 5 * v4 + v5 - 41) == 49 )
      exit(1);
    if ( *((_BYTE *)&v8 + 5 * v4 + v5 - 41) == 35 )
    {
      puts("\nok, the order you enter is the flag!");
      exit(0);
    }
  }
}

找到主要的地方:
BUUCTF Reverse 不一样的flag_第2张图片
要有个东西等于#就说明你输入的命令是正确的??
运行一下文件看看:
BUUCTF Reverse 不一样的flag_第3张图片
上下左右???
难不成是走迷宫???
直接查看字符串:
BUUCTF Reverse 不一样的flag_第4张图片
发现一串疑似地图的字符串
看看这个字符串在何处运用了:
在这里插入图片描述
原来在main函数中引用过
那么这应该就是地图了
直接分析一波代码:
BUUCTF Reverse 不一样的flag_第5张图片
上面什么都不用看,直接看这里,只要是1程序就结束。。。。
把地图拿出来分析一下,发现可以除以五:
BUUCTF Reverse 不一样的flag_第6张图片
直接按照命令来进行走
走0不走1
得到字符串:222441144222
提交~~正确!!!

你可能感兴趣的:(CTF题,BUUCTF,一天一道CTF)