新手一枚,如有错误(不足)请指正,谢谢!!
题目链接:BUUCTF-re-reverse3
下载地址:点击下载
此题同BugkuCTF re love

IDA32打开,找到_main函数

前往_main_0函数,F5伪代码
修改之后

int __cdecl main(int argc, const char **argv, const char **envp)
{
  int v3; // ebx
  int v4; // edi
  int v5; // esi
  int str_len; // eax
  const char *v7; // eax
  size_t Dest_len_; // eax
  char v10; // [esp+0h] [ebp-188h]
  char v11; // [esp+0h] [ebp-188h]
  signed int j; // [esp+DCh] [ebp-ACh]
  signed int i; // [esp+E8h] [ebp-A0h]
  signed int Dest_len; // [esp+E8h] [ebp-A0h]
  char Dest[108]; // [esp+F4h] [ebp-94h]
  char Str; // [esp+160h] [ebp-28h]
  char v17; // [esp+17Ch] [ebp-Ch]

  for ( i = 0; i < 100; ++i )
  {
    if ( (unsigned int)i >= 100 )
      j____report_rangecheckfailure(v3, v4, v5);
    Dest[i] = 0;                                // 对Dest进行初始化,每一位赋值为0
  }
  print((int)"please enter the flag:", v10);
  sub_411375("%20s", &Str);                     // 读取字符,最多读取20个字符给str
  str_len = j_strlen(&Str);                     // 读取str长度
  v7 = (const char *)sub_4110BE((int)&Str, str_len, (int)&v17);// base64加密,即v7为加密后的数据
  strncpy(Dest, v7, 40u);                       // 将v7的前40位复制给Dest
  Dest_len = j_strlen(Dest);                    // 读取Dest长度
  for ( j = 0; j < Dest_len; ++j )
    Dest[j] += j;                               // 对Dest的每位加上他们的下标
  Dest_len_ = j_strlen(Dest);
  if ( !strncmp(Dest, Str2, Dest_len_) )        // 如果Dest == Str2 则输出成功
                                                // Str2 = "e3nifIH9b_C@n@dH"
    print((int)"rigth flag!\n", v11);
  else
    print((int)"wrong flag!\n", v11);
  return 0;
}

其中sub_4110BE函数

// a1 为str的首地址
// a2 为 v3 即str的长度
// a3 为 字符v14的地址
void *__cdecl sub_411AB0(char *a1, unsigned int a2, int *a3)
{
  int v4; // STE0_4
  int v5; // STE0_4
  int v6; // STE0_4
  int v7; // [esp+D4h] [ebp-38h]
  signed int i; // [esp+E0h] [ebp-2Ch]
  unsigned int v9; // [esp+ECh] [ebp-20h]
  int v10; // [esp+ECh] [ebp-20h]
  signed int v11; // [esp+ECh] [ebp-20h]
  void *Dst; // [esp+F8h] [ebp-14h]
  char *v13; // [esp+104h] [ebp-8h]

  if ( !a1 || !a2 )                             // 如果a1 a2没有被传入
    return 0;                                   // 则退出
  v9 = a2 / 3;                                  // 即v9等于a2也就是str的长度除以3
  if ( (signed int)(a2 / 3) % 3 )               // 如果a2除以3后的余数不够3,则给v9加一
    ++v9;
  v10 = 4 * v9;
  *a3 = v10;
  Dst = malloc(v10 + 1);
  if ( !Dst )
    return 0;
  j_memset(Dst, 0, v10 + 1);
  v13 = a1;
  v11 = a2;
  v7 = 0;
  while ( v11 > 0 )
  {
    temp[2] = 0;
    temp[1] = 0;
    temp[0] = 0;
    for ( i = 0; i < 3 && v11 >= 1; ++i )
    {
      temp[i] = *v13;
      --v11;
      ++v13;
    }
    if ( !i )
      break;
    switch ( i )
    {
      case 1:
        *((_BYTE *)Dst + v7) = base64[(signed int)(unsigned __int8)temp[0] >> 2];
        v4 = v7 + 1;
        *((_BYTE *)Dst + v4++) = base64[((temp[1] & 0xF0) >> 4) | 16 * (temp[0] & 3)];
        *((_BYTE *)Dst + v4++) = base64[64];
        *((_BYTE *)Dst + v4) = base64[64];
        v7 = v4 + 1;
        break;
      case 2:
        *((_BYTE *)Dst + v7) = base64[(signed int)(unsigned __int8)temp[0] >> 2];
        v5 = v7 + 1;
        *((_BYTE *)Dst + v5++) = base64[((temp[1] & 0xF0) >> 4) | 16 * (temp[0] & 3)];
        *((_BYTE *)Dst + v5++) = base64[((temp[2] & 0xC0) >> 6) | 4 * (temp[1] & 0xF)];
        *((_BYTE *)Dst + v5) = base64[64];
        v7 = v5 + 1;
        break;
      case 3:
        *((_BYTE *)Dst + v7) = base64[(signed int)(unsigned __int8)temp[0] >> 2];
        v6 = v7 + 1;
        *((_BYTE *)Dst + v6++) = base64[((temp[1] & 0xF0) >> 4) | 16 * (temp[0] & 3)];
        *((_BYTE *)Dst + v6++) = base64[((temp[2] & 0xC0) >> 6) | 4 * (temp[1] & 0xF)];
        *((_BYTE *)Dst + v6) = base64[temp[2] & 0x3F];
        v7 = v6 + 1;
        break;
    }
  }
  *((_BYTE *)Dst + v7) = 0;
  return Dst;
}

base64这个字符串存放的……

可以确定是base64加密
开始写脚本……

然后进行base64解码Base64 编码/解码 | 菜鸟工具

所以flag为 flag{i_l0ve_you}

往期回顾

小白学习笔记(0) CG-CTF-re-3 py交易
小白学习笔记(1) BUUCTF-re xor
小白学习笔记(2)BUUCTF-re-新年快乐
小白学习笔记(3) CG-CT re ReadAsm2
小白学习笔记(4)BUUCTF-re-reverse_1
小白学习笔记(5)BUUCTF-re-内涵软件
小白学习笔记(6)BUUCTF-re-SimpleRev
小白学习笔记(7)BUUCTF-re-rsa
小白学习笔记(8)BUUCTF-re-CrackRTF
小白学习笔记(9)BUUCTF-re-刮开有奖
小白学习笔记(10)BUUCTF-re-Youngter-drive