小白学习笔记(11)BUUCTF-re-reverse3
2020-01-15 06:51
1096 查看
新手一枚,如有错误(不足)请指正,谢谢!!
题目链接: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
- 点赞
- 收藏
- 分享
- 文章举报
相关文章推荐
- 小白学习笔记(23)BUUCTF-re-[SWPU2019]ReverseMe
- 小白学习笔记(24)BUUCTF-re-[2019红帽杯]childRE
- 小白学习笔记(13)BugkuCTF-re-file
- 小白学习笔记(12)BugkuCTF-re-游戏过关
- 小白学习笔记(22)爱春秋CTF答题夺旗赛(第四季)-re-basebasebase
- 小白学习笔记(21)攻防世界-re进阶区-Shuffle
- 小白学习笔记(20)i春秋-re-Nonstandard
- 小白学习笔记(19)i春秋-re-crackme
- 小白学习笔记(18)攻防世界-re新手区-maze
- 【小白笔记】PHP学习之路 (11) --数组(1)
- 小白学习笔记(17)CG-CTF-re-签到题 (Z3约束器)
- 小白学习笔记(16)CG-CTF-re-Single
- 小白学习笔记(15)CG-CTF-re-你大概需要一个优秀的mac
- 小白学习笔记(14)CG-CTF-re-WxyVM
- 关于小白学习struts2的笔记
- Flex学习笔记11——MVC
- 操作系统学习笔记(11)--makefile的$@
- Perl 学习笔记 --- 11
- Shell学习笔记(11)-流程控制之select、until语句
- Practical Rendering and Computation with Direct3D 11学习笔记(2.2.2)