ベンダーベンダーからのファイルをFTP経由でFTP経由でFTPに変更しています。TLS/SSL経由でFTP経由で未認証のホストに接続
私はnet/ftp
からnet/ftptls
私は接続する必要が新しいホストが保証されていませんし、私のスクリプトが戻ってこのエラーを報告し、私のコードを更新しようとしています。
ホスト名は、ベンダーはこの問題を解決しませんサーバー証明書
と一致していませんでした。
投稿者/usr/lib/ruby/1.8/net/ftptls.rb
私は、monkey-patch 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
ctx.cert = nil
voidcmd("AUTH TLS")
@sock = OpenSSL::SSL::SSLSocket.new(@sock, ctx)
@sock.connect
@sock.post_connection_check(@hostname)
super(user, passwd, acct)
voidcmd("PBSZ 0")
end
end
end