cURL
Haxx ad
libcurl

curl's project page on SourceForge.net

Sponsors:
Haxx

cURL > Mailing List > Monthly Index > Single Mail

curl-tracker mailing list Archives

[ curl-Bugs-1469799 ] FTP PORT command sends bad IP

From: SourceForge.net <noreply_at_sourceforge.net>
Date: Thu, 13 Apr 2006 06:08:50 -0700

Bugs item #1469799, was opened at 2006-04-13 06:08
Message generated for change (Tracker Item Submitted) made by Item Submitter
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=100976&aid=1469799&group_id=976

Please note that this message will contain a full copy of the comment thread,
including the initial issue submission, for this request,
not just the latest update.
Category: ftp
Group: bad behaviour
Status: Open
Resolution: None
Priority: 5
Submitted By: Nobody/Anonymous (nobody)
Assigned to: Daniel Stenberg (bagder)
Summary: FTP PORT command sends bad IP

Initial Comment:
While using libcurl 7.15.3 on a Linux Debian 3.1
platform to perform a FTP file listing (custom command
NLST *) in active mode. The client has a private IP and
 connects to the server through a FTP proxy.

Sometimes the listing succeeds (but note the strange
host name) :

* About to connect() to 132.456.789.12 port 21
* Trying 132.456.789.12... * connected
* Connected to 132.456.789.12 (132.456.789.12) port 21
* FTP 0x8d9919c state change from STOP to WAIT220
< 220 SERVER01 Microsoft FTP Service (Version 5.0).
> USER user
* FTP 0x8d9919c state change from WAIT220 to USER
< 331 Password required for user.
> PASS password
* FTP 0x8d9919c state change from USER to PASS
< 230 User user logged in.
> PWD
* FTP 0x8d9919c state change from PASS to PWD
< 257 "/user" is current directory.
* Entry path is '/user'
* FTP 0x8d9919c state change from PWD to STOP
* protocol connect phase DONE
* DO phase starts
* gethostbyname_r(2) failed for £@pOA
* Failed to resolve host name £@pOA
* Telling server to connect to 192.168.1.24:54115
> PORT 192,168,1,24,211,99
* FTP 0x8d9919c state change from STOP to PORT
< 200 PORT command successful.
* Connect data stream actively
* FTP 0x8d9919c state change from PORT to STOP
* DO phase is complete
* DO-MORE phase starts
> TYPE A
* FTP 0x8d9919c state change from STOP to LIST_TYPE
< 200 Type set to A.
> NLST *
* FTP 0x8d9919c state change from LIST_TYPE to LIST
< 150 Opening ASCII mode data connection for file list.
* Connection accepted from server
* FTP 0x8d9919c state change from LIST to STOP
* DO-MORE phase ends
< 226 Transfer complete.
* Connection #0 to host 132.456.789.12 left intact
> QUIT
* FTP 0x8d9919c state change from STOP to QUIT
< 221
* FTP 0x8d9919c state change from QUIT to STOP
* Closing connection #0

Sometimes it fails (because PORT gives server's IP
instead of its own IP):

* About to connect() to 132.456.789.12 port 21
* Trying 132.456.789.12... * connected
* Connected to 132.456.789.12 (132.456.789.12) port 21
* FTP 0x8c3a554 state change from STOP to WAIT220
< 220 SERVER01 Microsoft FTP Service (Version 5.0).
> USER user
* FTP 0x8c3a554 state change from WAIT220 to USER
< 331 Password required for user.
> PASS password
* FTP 0x8c3a554 state change from USER to PASS
< 230 User user logged in.
> PWD
* FTP 0x8c3a554 state change from PASS to PWD
< 257 "/user" is current directory.
* Entry path is '/user'
* FTP 0x8c3a554 state change from PWD to STOP
* protocol connect phase DONE
* DO phase starts
* Telling server to connect to 132.456.789.12:54054
> PORT 132,456,789,12,211,38
* FTP 0x8c3a554 state change from STOP to PORT
< 200 PORT command successful.
* Connect data stream actively
* FTP 0x8c3a554 state change from PORT to STOP
* DO phase is complete
* DO-MORE phase starts
> TYPE A
* FTP 0x8c3a554 state change from STOP to LIST_TYPE
< 200 Type set to A.
> NLST *
* FTP 0x8c3a554 state change from LIST_TYPE to LIST
< 150 Opening ASCII mode data connection for file list.
* Timeout while waiting for server connect
* DO-MORE phase ends
* Connection #0 to host 132.456.789.12 left intact
* FTP command PORT failed
> QUIT
* FTP 0x8c3a554 state change from LIST to QUIT
* FTP response reading failed
* Closing connection #0

It seems the code in ftp.c (v 1.349 2006/02/11
22:35:17) (line 1006) has a problem:

if(data->set.ftpport)

At this point, I could always see data->set.ftpport
being non null, either:
- a non significant value (the '£@pOA' from above)
- the value 'NLST *'

A convenient solution for me was to remove code from
line 1006 to 1042.

Hope this helps.
vincent.guer at neolane.net

----------------------------------------------------------------------

You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=100976&aid=1469799&group_id=976
Received on 2006-04-13

These mail archives are generated by hypermail.

donate! Page updated November 12, 2010.
web site info

File upload with ASP.NET