2013-03-06 50 views
0

我试过几个宝石,实例等,并不能得到这个工作,更有前途的宝石分别为:double-bag-ftpsFTPFXP,我可以连接,但我无法传输文件,在主动或被动模式..任何人都可以工作FTPS/FTP :: TLS在Ruby 1.9.3下?

样本代码与ftpfxp:

:与双袋

ftps = DoubleBagFTPS.new 
ftps.ssl_context = DoubleBagFTPS.create_ssl_context(:verify_mode => OpenSSL::SSL::VERIFY_NONE) 
ftps.connect('192.168.0.2') 
ftps.login('myuser2', 'mypass2') 
ftps.chdir('/') 
ftps.get("data.txt") 
ftps.close 

样品误差:与双袋

@conn2 = Net::FTPFXPTLS.new 
@conn2.passive = true 
@conn2.debug_mode = true 
@conn2.connect('192.168.0.2', 990) 
@conn2.login('myuser2', 'mypass2') 
@conn2.chdir('/') 
@conn2.get("data.txt") 
@conn2.close 

示例代码

~/.rbenv/versions/1.9.3-p385/lib/ruby/gems/1.9.1/gems/double-bag-ftps-0.1.0/lib/double_bag_ftps.rb:148:in `connect': Broken pipe - SSL_connect (Errno::EPIPE) 

样品误差ftpfxp:

~/.rbenv/versions/1.9.3-p385/lib/ruby/1.9.1/net/ftp.rb:206:in `initialize': No route to host - connect(2) (Errno::EHOSTUNREACH) 

任何recomendation不涉及外部命令?

谢谢。

回答

0

我已经解决了这个问题,服务器正在返回一个私人IP地址,同时试图以明确的tls进行pasive模式连接,所以我已经添加了一行到Double-Bag-FTPS来检查返回的IP是私人退回到原来的公网IP地址...

GitHub Pull request

因此,如果有人有相同的问题,也许这就是答案希望这可以帮助别人:)

相关问题