0

以下のコードの場合certificate verify failed (OpenSSL::SSL::SSLError):

コード

require 'mechanize'

agent = Mechanize.new

#{|a| a.ssl_version, a.verify_mode = 'SSLv3', OpenSSL::SSL::VERIFY_NONE}

agent.set_proxy('3.209.30.25', 80)
agent.ssl_version='SSLv3'
agent.verify_mode= OpenSSL::SSL::VERIFY_PEER

page = agent.get "https://gegsltraining.aravo.com/"

エラー

C:/Ruby193/lib/ruby/gems/1.9.1/gems/net-http-persistent-2.8/lib/net/http/persist
ent/ssl_reuse.rb:70:in `connect': SSL_connect returned=1 errno=0 state=SSLv3 rea
d server certificate B: certificate verify failed (OpenSSL::SSL::SSLError)

編集

次のようにコードを変更しました。

require 'mechanize'
agent = Mechanize.new
#{|a| a.ssl_version, a.verify_mode = 'SSLv3', OpenSSL::SSL::VERIFY_NONE}
agent.set_proxy('3.209.30.25', 80)
agent.ssl_version='SSLv3'
cert_store = OpenSSL::X509::Store.new
cert_store.add_file 'E:\WIPData\Ruby\Scripts\cacert.pem'
agent.cert_store = cert_store
agent.verify_mode= OpenSSL::SSL::VERIFY_PEER (tried OpenSSL::SSL::VERIFY_NONE none of them going good)

新しいエラー

E:\WIPData\Ruby\Scripts>mechanizev1.rb
C:/Ruby193/lib/ruby/1.9.1/net/http.rb:2632:in `error!': 500 "Internal Server Err
or" (Net::HTTPFatalError)

その認証検証を正常に行うにはどうすればよいですか? 助けて。

4

1 に答える 1

0

このファイルを指すように機械化エージェントobject.http.ca_fileを設定するだけです。

agent.agent.http.ca_file = '/etc/ssl/certs/curl-ca-bundle.crt'

これを行う別の方法は、curl-ca-bundle.crtをapp libディレクトリに保存してから、設定することです。

agent.agent.http.ca_file = 'lib/curl-ca-bundle.crt'
于 2013-01-23T08:44:51.297 に答える