имя хоста не соответствует сертификату сервера - не удается отправить электронную почту
Я использую Pony mail для отправки сообщений электронной почты (потому что я никогда не мог заставить ActionMailer работать на моем локальном окне Windows).
код в моем user_mailer.файл rb включает этот вызов пони.метод mail:
Pony.mail({
:to => email_address,
:from => 'MyChairSales <support@mychairsales.com>',
:subject => subject,
:body => email_body,
:html_body => html_body,
:via => :smtp,
:via_options => {
:address => 'mail.mychairsales.com',
:port => '25',
:enable_starttls_auto => true,
:user_name => 'mychairs',
:password => 'thepassword',
:domain => "mychairsales.com" # the HELO domain provided by the client to the server
}
})
это работало (я получил электронное письмо с помощью этого метода), но теперь сбой с ошибкой "имя хоста не соответствует сертификату сервера".
вот верхняя часть трассировки стека:
["/usr/lib64/ruby/1.9.3/openssl/ssl-internal.rb:121:in `post_connection_check'",
"/usr/lib64/ruby/1.9.3/net/smtp.rb:585:in `tlsconnect'", "/usr/lib64/ruby/1.9.3
/net/smtp.rb:560:in `do_start'", "/usr/lib64/ruby/1.9.3/net/smtp.rb:519:in `start'",
"/home4/mychairs/ruby/gems/gems/mail-2.4.4/lib/mail/network/delivery_methods
/smtp.rb:144:in `deliver!'", "/home4/mychairs/ruby/gems/gems/mail-2.4.4/lib
/mail/message.rb:245:in `deliver!'", "/home4/mychairs/ruby/gems/gems/pony-1.4/lib
/pony.rb:166:in `deliver'", "/home4/mychairs/ruby/gems/gems/pony-1.4/lib
/pony.rb:138:in `mail'", "/home4/mychairs/rails_apps/chairsales/app/mailers
/user_mailer.rb:32:in `send_mail'", "/home4/mychairs/rails_apps/chairsales/app/mailers
/user_mailer.rb:23:in `send_password_reset_email'",...
любое наведение было бы очень признателен!
1 ответов
немного поздно, но я также столкнулся с этой ошибкой, но с Ruby Mail gem. Если ваш SMTP-сервер поддерживает TLS, он попытается использовать TLS и аутентифицировать сертификат SSL. Если сертификат выдается для имени хоста, отличного от используемого, или если сертификат не может быть аутентифицирован (например, если он самозаверяющий, и вы не доверяете CA), то он завершится ошибкой "имя хоста не соответствует сертификату сервера".
чтобы обойти это, используйте :вариант openssl_verify_mode. Это может быть установлено в OpenSSL::SSL:: VERIFY_NONE, чтобы не выполнять проверку сертификата - он все равно зашифрует сеанс SMTP. Или есть другие варианты, доступные в библиотеке OpenSSL.
используя Ваш пример, это будет выглядеть так:
Pony.mail({
:to => email_address,
:from => 'MyChairSales <support@mychairsales.com>',
:subject => subject,
:body => email_body,
:html_body => html_body,
:via => :smtp,
:via_options => {
:openssl_verify_mode => OpenSSL::SSL::VERIFY_NONE,
:address => 'mail.mychairsales.com',
:port => '25',
:enable_starttls_auto => true,
:user_name => 'mychairs',
:password => 'thepassword',
:domain => "mychairsales.com" # the HELO domain provided by the client to the server
}
})
Это также работает и для почтового драгоценного камня.