攻防世界 reverse seven

seven  hctf2018

 这是一个驱动文件

 ida载入,查找字符串

 

 

 根据字符串来到函数:sub_1400012F0

__int64 __fastcall sub_1400012F0(__int64 a1, __int64 a2)
{
  __int64 v2; // rbx
  _KEYBOARD_INPUT_DATA *KEYBOARD_input; // rsi
  unsigned __int64 v4; // rdx
  int index; // ecx
  __int16 *k_ipt; // rdi
  __int64 v7; // rbp
  __int16 k; // dx
  char next_c; // dl
  CHAR *v10; // rcx

  v2 = a2;
  if ( *(_DWORD *)(a2 + 48) >= 0 )
  {
    KEYBOARD_input = *(_KEYBOARD_INPUT_DATA **)(a2 + 24);
    v4 = (unsigned __int64)(*(unsigned __int64 *)(a2 + 56) * (unsigned __int128)0xAAAAAAAAAAAAAAABui64 >> 64) >> 3;
    if ( (_DWORD)v4 )
    {
      index = dword_1400030E4;
      k_ipt = (__int16 *)&KEYBOARD_input->MakeCode;
      v7 = (unsigned int)v4;
      while ( KEYBOARD_input->Flags )
      {
LABEL_30:
        k_ipt += 6;
        if ( !--v7 )
          goto LABEL_31;
      }
      aO[index] = '.';
      k = *k_ipt;
      if ( *k_ipt == 17 )//对应按键w
      {
        if ( index & 0xFFFFFFF0 )               // 大于等于16
        {
          index -= 16;                          // 向上移动
          goto LABEL_13;
        }
        index += 208;
        dword_1400030E4 = index;
      }
      if ( k != 31 )//对应按键s
        goto LABEL_14;
      if ( (index & 0xFFFFFFF0) == 208 )
        index -= 208;
      else
        index += 16;                            // 向下移动
LABEL_13:
      dword_1400030E4 = index;
LABEL_14:
      if ( k == 30 )//对应按键a
      {
        if ( index & 0xF )
          --index;                              // 向左
        else
          index += 15;                          // 最右端0位置时,+15,向左移动到最右端
        dword_1400030E4 = index;
      }
      if ( k == 32 )//对应按键d
      {
        if ( (index & 0xF) == 15 )              // 右,一行0-15,16个,在最右端时,移到0位置
          index -= 15;
        else
          ++index;                              //
        dword_1400030E4 = index;
      }
      next_c = aO[index];
      if ( next_c == '*' )
      {
        v10 = "-1s\n";
      }
      else
      {
        if ( next_c != '7' )
        {
LABEL_29:
          aO[index] = 'o';
          goto LABEL_30;
        }
        v10 = "The input is the flag!\n";
      }
      dword_1400030E4 = 16;
      DbgPrint(v10);
      index = dword_1400030E4;
      goto LABEL_29;
    }
  }
LABEL_31:
  if ( *(_BYTE *)(v2 + 65) )
    *(_BYTE *)(*(_QWORD *)(v2 + 184) + 3i64) |= 1u;
  return *(unsigned int *)(v2 + 48);
}

简单的迷宫题,输入是通过KEYBOARD_INPUT_DATA结构体,其第二项表示按键的扫描码

17-->w; 31-->s; 30-->a; 32-->d

分别对应上,下,左,右。

迷宫:

 

 对应输入:ddddddddddddddssaasasasasasasasasas

hctf{ddddddddddddddssaasasasasasasasasas}

posted @ 2020-02-07 14:29  DirWangK  阅读(372)  评论(0编辑  收藏  举报