GMX && Ruby Mail SMTP: "достигнут конец файла"

Я не могу получить Mail (или же Pony в этом отношении), чтобы соединиться, чтобы послать электронную почту через сервер SMTP с учетными данными, номером порта и параметром адреса, который я знаю, являются правильными. Тем не менее, при использовании почтового клиента (Thunderbird, чернила... и т. Д.) Я могу подключиться очень хорошо.

Вот трассировка стека, которую я получаю:

ruby gmx_test.rb
/Users/sy/.rvm/rubies/ruby-2.1.0/lib/ruby/2.1.0/net/protocol.rb:153:in `read_nonblock': end of file reached (EOFError)
    from /Users/sy/.rvm/rubies/ruby-2.1.0/lib/ruby/2.1.0/net/protocol.rb:153:in `rbuf_fill'
    from /Users/sy/.rvm/rubies/ruby-2.1.0/lib/ruby/2.1.0/net/protocol.rb:134:in `readuntil'
    from /Users/sy/.rvm/rubies/ruby-2.1.0/lib/ruby/2.1.0/net/protocol.rb:144:in `readline'
    from /Users/sy/.rvm/rubies/ruby-2.1.0/lib/ruby/2.1.0/net/smtp.rb:937:in `recv_response'
    from /Users/sy/.rvm/rubies/ruby-2.1.0/lib/ruby/2.1.0/net/smtp.rb:554:in `block in do_start'
    from /Users/sy/.rvm/rubies/ruby-2.1.0/lib/ruby/2.1.0/net/smtp.rb:947:in `critical'
    from /Users/sy/.rvm/rubies/ruby-2.1.0/lib/ruby/2.1.0/net/smtp.rb:554:in `do_start'
    from /Users/sy/.rvm/rubies/ruby-2.1.0/lib/ruby/2.1.0/net/smtp.rb:519:in `start'
    from /Users/sy/.rvm/gems/ruby-2.1.0/gems/mail-2.5.4/lib/mail/network/delivery_methods/smtp.rb:112:in `deliver!'
    from /Users/sy/.rvm/gems/ruby-2.1.0/gems/mail-2.5.4/lib/mail/message.rb:2129:in `do_delivery'
    from /Users/sy/.rvm/gems/ruby-2.1.0/gems/mail-2.5.4/lib/mail/message.rb:234:in `deliver'
    from /Users/sy/.rvm/gems/ruby-2.1.0/gems/mail-2.5.4/lib/mail/mail.rb:140:in `deliver'
    from gmx_test.rb:29:in `<main>'

Вот генерация кода:

require 'mail'

gmx_options = { :address              => "mail.gmx.com",
                :port                 => 465,
                :user_name            => '<username_redacted>@gmx.com',
                :password             => '<password_redacted>',
                :authentication       => 'plain',
                :enable_starttls_auto => true  }



Mail.defaults do
  delivery_method :smtp, gmx_options
end



Mail.deliver do
  to '<redacted>
  from '<username_redacted>@gmx.com'
  subject 'TEST'
  body 'Hi.'
end

Вот снимок экрана настроек сервера одного из почтовых клиентов настольного компьютера, который может отправлять электронные письма:

введите описание изображения здесь

Окончательный поворот сюжета: этот код работает, если я использую SMTP в Gmail.

Спасибо за понимание, ребята!

1 ответ

Я столкнулся с этой проблемой в 2017 году, и у меня сработало простое изменение порта на 587:

Немецкий источник https://hilfe.gmx.net/pop-imap/pop3/serverdaten.html существу утверждает, что порт 465 работает с SSL-шифрованием, для STARTTLS-шифрования вы должны использовать порт 587.

Другие вопросы по тегам