re学习笔记(47)BUUCTF-re-[V&N2020 公开赛]strangeCpp

新手一枚,如有错误(不足)请指正,谢谢!!
个人博客:点击进入
题目链接:BUUCTF-re-[V&N2020 公开赛]strangeCpp

main()函数没啥东西……
找好久…
在这里插入图片描述
putchar字节这里,中间夹杂着数据……

在这里插入图片描述
然后交叉引用,来到这里
在这里插入图片描述
其中sub_140011384()函数,将dword_140021190操作得到result
在这里插入图片描述
然后result要等于607052314,dword_140021190要小于等于14549743
缩小爆破范围……
写脚本

#include <stdio.h>
int main()
{
    unsigned char data[17] = {
    0x26, 0x2C, 0x21, 0x27, 0x3B, 0x0D, 0x04, 0x75, 0x68, 0x34, 0x28, 0x25, 0x0E, 0x35, 0x2D, 0x69,
    0x3D
    };
    int i,m,result = 607052314;
    int n=0;
    for (n = 0; n <= 14549743; n++)
    {
        m= (n << 8) ^ (n >> 12);
        if (m*291 == result)
        {
            printf("%d\n", n);
            break;
        }
    }
    for (i = 0; i < 17; i++)
        putchar(data[i] ^ char(n));
    
    return 0;
}

在这里插入图片描述
使用python进行md5加密
在这里插入图片描述

得到最终flag为flag{e10adc3949ba59abbe56e057f20f883e}

发布了62 篇原创文章 · 获赞 11 · 访问量 5879

猜你喜欢

转载自blog.csdn.net/Palmer9/article/details/104578880