2013-03-27 11 views
5

ho cercato di utilizzare l'FTP in modalità passiva: errore
rubino FTP in modalità passiva errore

require 'net/ftp' 
ftp = Net::FTP.new 
ftp.passive = true 
ftp.connect('mydomain.com') 
ftp.login 
filenames = ftp.nlst 

Ma hanno ottenuto:

Errno::ETIMEDOUT: Connection timed out - connect(2) 

Anche se con modalità attiva funziona benissimo!

Io uso rubino 1.9.3. Quando ho creato debuge modalità:

ftp.debug_mode = true 

vedo:

**ftp.connect('mydomain.com')** 
connect: mydomain.com, 21 
get: 220---------- Welcome to Pure-FTPd [privsep] ---------- 
get: 220-You are user number 3 of 50 allowed. 
get: 220-Local time is now 11:43. Server port: 21. 
get: 220-IPv6 connections are also welcome on this server. 
get: 220 You will be disconnected after 15 minutes of inactivity. 
=> nil 
irb(main):103:0> ftp.login 
put: USER anonymous 
get: 230 Anonymous user logged in 
put: TYPE I 
get: 200 TYPE is now 8-bit binary 
=> true 
irb(main):104:0> filenames = ftp.nlst 
put: TYPE A 
get: 200 TYPE is now ASCII 
put: PASV 
get: 227 Entering Passive Mode (1,27,13,19,17,15) 
put: TYPE I 
get: 200 TYPE is now 8-bit binary 
Errno::ETIMEDOUT: Connection timed out - connect(2) 

Inoltre ho scoperto che, in funzione transfercmd da Net::FTP host viene utilizzato, diverso dal mio indirizzo IP del dominio! Forse è un indirizzo IP privato? Cosa c'è di sbagliato qui?

+0

Sei sicuro che il tuo server consenta la modalità passiva? Sembra che le porte siano chiuse –

+0

Hai controllato che il tuo server abbia la possibilità di collegare la modalità passiva? – xyz

+0

Sì, il mio server offre la possibilità di collegare la modalità passiva. Ho controllato usando il client FTP. – Vasilina

risposta

4

Ho sovrascritto il metodo makepasv da Net::FTP e funziona!

module Net 
    class FTP 
    def makepasv # :nodoc: 
     if @sock.peeraddr[0] == "AF_INET" 
     #host, port = parse227(sendcmd("PASV")) #WAS! 
     host, port = parse229(sendcmd("EPSV")) 
     else 
     host, port = parse229(sendcmd("EPSV")) 
     end 
     return host, port 
    end 
    end 
end 
+1

Bel lavoro, questo ha fatto il trucco, c'è una correzione di patch da qualche parte! –