Tag: ftps

通过FTP通过TLS / SSL连接到未经认证的主机

我从中获取文件的供应商正在通过SSL从FTP更改为FTP。 我正在尝试将我的代码从net/ftp更新为net/ftptls 我需要连接的新主机未经过认证,我的脚本会报告此错误。 hostname与服务器证书不匹配 供应商不会解决这个问题。 看看/usr/lib/ruby/1.8/net/ftptls.rb我认为通过猴子修补FTPTLS来忽略不受信任的主机并不会太难。 我尝试将verify_mode更改为OpenSSL::SSL::VERIFY_NONE并注释掉post_connection_check`行。 既没有奏效。 有关如何做到这一点的任何想法? require ‘socket’ require ‘openssl’ require ‘net/ftp’ module Net class FTPTLS < FTP def connect(host, port=FTP_PORT) @hostname = host super end def login(user = "anonymous", passwd = nil, acct = nil) store = OpenSSL::X509::Store.new store.set_default_paths ctx = OpenSSL::SSL::SSLContext.new('SSLv23') ctx.cert_store = store ctx.verify_mode = OpenSSL::SSL::VERIFY_PEER ctx.key = nil […]