当我尝试打开与Office 365服务的连接时,它会失败:
2.2.0 :001 > require 'net/imap'
=> true
2.2.0 :002 > port = '993'
=> "993"
2.2.0 :003 > imap = Net::IMAP.new('outlook.office365.com', port)
Net::IMAP::Error: connection closed
from /Users/cameronaziz/.rvm/rubies/ruby-2.2.0/lib/ruby/2.2.0/net/imap.rb:1077:in `initialize'
from (irb):3:in `new'
from (irb):3
我还需要设置什么?
这是我的控制器中的代码:
require 'net/imap'
port = '993'
imap = Net::IMAP.new('outlook.office365.com', port)
imap.authenticate('LOGIN', '***@***.com', '***')
imap.examine('INBOX')
在我实际设置用户名/密码之前,new
命令(与控制台相同)失败。
~~~~~~~
设置:ssl => true
有效。但是现在我仍然无法连接,因为我得到了:
控制器:
imap = Net::IMAP.new('outlook.office365.com', {:port => '993', :ssl => true } )
imap.authenticate('LOGIN', '***@***.com', '***')
视图错误:
Net::IMAP::BadResponseError in EmailsController#connect
Command Argument Error. 11
视图中突出显示的行现在位于authenticate
方法行。
当我运行imap.capability
时:
["IMAP4", "IMAP4REV1", "AUTH=PLAIN", "AUTH=XOAUTH2", "SASL-IR", "UIDPLUS", "ID", "UNSELECT", "CHILDREN", "IDLE", "NAMESPACE", "LITERAL+"]
答案 0 :(得分:3)
IMAP可能正在关闭连接,因为您没有及时(或根本)进行身份验证。
您应该使用Net::IMAP#login
或Net::IMAP#authenticate
方法进行身份验证。
来自the docs:
imap.authenticate('LOGIN', 'username', password)
这也应该有效:
imap.login('username', 'password')
请注意,LOGIN
可能不是您的身份验证方法。您可能需要先致电imap.capability
,然后确定是继续使用LOGIN
还是CRAM-MD5
。
答案 1 :(得分:0)
端口993通常是通过SSL IMAP连接的方式,因此您需要告诉ruby您需要通过SSL连接,例如:
imap = Net::IMAP.new('outlook.office365.com', 993, ssl: true)
然后,您可以使用登录或身份验证连接到用户的邮箱。
ruby doc表示如果使用authenticate方法,则需要确保imap服务器可以支持“LOGIN”或“CRAM-MD5”,但是在您提供的列表中我看不到任何这些
[“IMAP4”,“IMAP4REV1”,“AUTH = PLAIN”,“AUTH = XOAUTH2”,“SASL-IR”,“UIDPLUS”,“ID”,“UNSELECT”,“CHILDREN”,“IDLE”, “NAMESPACE”,“LITERAL +”]
因此登录outlook imap的唯一方法是使用map.login方法,例如:
imap.login(login, password
)