2

我正在尝试使用 IMAP,但它不起作用。我对“https”进行了同样的尝试,它奏效了。


require 'net/imap' 
=> true
irb(main):002:0> Net::IMAP.new("xxx", 993, true).login("redmine", "redmine")
OpenSSL::SSL::SSLError: SSL_connect returned=1 errno=0 state=SSLv3 read server certificate B: certificate verify failed
    from /usr/local/lib/ruby/1.9.1/net/imap.rb:1439:in `connect'
    from /usr/local/lib/ruby/1.9.1/net/imap.rb:1439:in `start_tls_session'
    from /usr/local/lib/ruby/1.9.1/net/imap.rb:1036:in `initialize'
    from (irb):2:in `new'
    from (irb):2
    from /usr/local/bin/irb:12:in `<main>'
irb(main):003:0> 

ruby 1.9.3p0 (2011-10-30 revision 33570) [x86_64-linux]
gem -v 1.8.24

这类似于:https ://www.chiliproject.org/boards/1/topics/2076


openssl s_client -connect klevas.mif.vu.lt:imaps 

显示证书已过期。但是,在 Ruby 和 Gem 相同的另一个系统上,IMAP 连接有效。

4

2 回答 2

3

如果我们在这里讨论 redmine,以下内容很有帮助。

在第 29 行的 lib/redmine/imap.rb 中有一个调用

imap = Net::IMAP.new(host, port, ssl)

根据从/usr/lib/ruby/1.9.1/net/imap.rb了解到的信息

    def initialize(host, port_or_options = {},
               usessl = false, certs = nil, verify = true)

我把它改成

imap = Net::IMAP.new(host, port, ssl, nil, false)

错误消失了

于 2014-05-08T13:50:52.063 回答
3

试试这个: imap = Net::IMAP.new('xxx', {:ssl => {:verify_mode => 0 }})

于 2013-07-19T16:57:57.220 回答