Получение & # 8220; Сначала необходимо выполнить команду STARTTLS & # 8221; при попытке отправить письмо
-
08-07-2019 - |
Вопрос
Я получаю сообщение об ошибке при попытке использовать плагин action_mailer_tls
для связи с Gmail в моем приложении Rails:
Must issue a STARTTLS command first
Решение
Я использовал решение Александра Помозова, чтобы общаться с Gmail из моего приложения на Rails. Я считаю, что оригинальная статья пропала, но кто-то воспроизвел кеш Google здесь .
Библиотека / smtp_tls.rb
require "openssl"
require "net/smtp"
Net::SMTP.class_eval do
private
def do_start(helodomain, user, secret, authtype)
raise IOError, 'SMTP session already started' if @started
check_auth_args user, secret, authtype if user or secret
sock = timeout(@open_timeout) { TCPSocket.open(@address, @port) }
@socket = Net::InternetMessageIO.new(sock)
@socket.read_timeout = 60 #@read_timeout
#@socket.debug_output = STDERR #@debug_output
check_response(critical { recv_response() })
do_helo(helodomain)
if starttls
raise 'openssl library not installed' unless defined?(OpenSSL)
ssl = OpenSSL::SSL::SSLSocket.new(sock)
ssl.sync_close = true
ssl.connect
@socket = Net::InternetMessageIO.new(ssl)
@socket.read_timeout = 60 #@read_timeout
#@socket.debug_output = STDERR #@debug_output
do_helo(helodomain)
end
authenticate user, secret, authtype if user
@started = true
ensure
unless @started
# authentication failed, cancel connection.
@socket.close if not @started and @socket and not @socket.closed?
@socket = nil
end
end
def do_helo(helodomain)
begin
if @esmtp
ehlo helodomain
else
helo helodomain
end
rescue Net::ProtocolError
if @esmtp
@esmtp = false
@error_occured = false
retry
end
raise
end
end
def starttls
getok('STARTTLS') rescue return false
return true
end
def quit
begin
getok('QUIT')
rescue EOFError, OpenSSL::SSL::SSLError
end
end
end
конфиг / environment.rb
(добавить после всего остального)
require “smtp_tls”
ActionMailer::Base.smtp_settings = {
:address => “smtp.gmail.com”,
:port => 587,
:authentication => :plain,
:user_name => “someone@openrain.com”,
:password => ’someonesPassword’
}
Используйте ActionMailer как обычно.
Другие советы
С Ruby 1.8.7 и Rails 2.3.4 (хотя он был там уже в нескольких выпусках) я добился успеха без необходимости в специфичных для TLS плагинах ActionMailer с помощью параметра : enable_starttls_auto
, Пример конфигурации (из производственной среды) выглядит следующим образом:
ActionMailer::Base.smtp_settings = {
:enable_starttls_auto => true,
:address => "smtp.gmail.com",
:port => 587,
:domain => "domain.com",
:authentication => :plain,
:user_name => "username@domain",
:password => "secret"
}
Я включил starttls, используя : enable_starttls_auto = > true
, но все равно получена та же ошибка. Наконец-то я смог решить эту проблему без единого изменения в коде. Если вы используете smtp.gmail.com для отправки почты, вы должны сначала разрешить менее безопасным приложениям использовать вашу электронную почту для отправки почты. Для этого войдите под своей учетной записью, с которой вы хотите отправлять почту, и перейдите на
эту ссылку и включите доступ в менее безопасные приложения.
Изменить. Если вам не разрешено изменять настройки менее защищенных приложений, обратитесь к владельцу учетной записи администратора этого домена, чтобы изменить настройки, чтобы пользователи могли использовать менее защищенные приложения.
Если у вас есть права администратора, вы можете разрешить пользователям изменять свои менее безопасные настройки приложения, вы можете изменить их с https://admin.google.com/domainname.com/AdminHome#ServiceSettings/notab=1&service=securitysetting&subtab=lesssecureappsaccess
PS: не забудьте изменить имя домена в приведенной выше ссылке.
Надеюсь, это чертовски !!
Я использую rails 2.3.4, и хотя я подумал (из-за того, что гуглил), вам не нужны плагины, а только строка
: enable_starttls_auto = > правда,
На самом деле я получил его на работу, только когда использовал решение Александра Помозова, опубликованное на лыже выше (большое спасибо вам, ребята). Есть комментарии, почему? было бы здорово, но я просто счастлив, что это работает.