天天看點

BUUCTF reverse:不一樣的flag

1.查殼

BUUCTF reverse:不一樣的flag

無殼,32位檔案

2.IDA分析

找到main函數,F5反編譯

BUUCTF reverse:不一樣的flag
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);
    }
  }
}
           
puts("1 up");
puts("2 down");
puts("3 left");
printf("4 right\n:");
           

看到上下左右的輸入提示,猜測這個題可能是走迷宮

注意到這行代碼

_data_start__

是一個長度為26的字元串,除去一個空字元,存儲的資料為25個,是以猜測是一個5*5的迷宮

輕按兩下進入

_data_start__

__data_start__  db '*11110100001010000101111#',0
           
*1111
01000
01010
00010
1111#
           
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);
    }
           

這幾行代碼告訴我們,不能走到‘1’處,否則退出,并且我們需要走到‘#’處,走到‘#’的方向連起來就是我們的flag

起點在左上角的‘*’處

是以我們的flag為

222441144222