Получение "сначала необходимо выполнить команду STARTTLS" при попытке отправить электронное письмо
Я получаю ошибку при попытке использовать action_mailer_tls
плагин для связи с Gmail в моем приложении Rails:
Must issue a STARTTLS command first
другие, кажется, столкнулись эта же проблема:
проблема в том, что Gmail требует TLS аутентификация, но стандартный Ruby библиотека net / smtp не поддерживает TLS.
статьи рекомендует следующие шаги, которые я сделал:
конечно есть полезный плагин создано Marc Chung для преодоления этого барьер. Вы можете найти его здесь и вручную добавить его в свой проект или вы может экспортировать его в свой плагин справочник.
$ cd vendor/plugins
$ svn export http://code.openrain.com/rails/action_mailer_tls/
в любом случае убедитесь, что вы требуете 'smtp_tls'
теперь все, что вам нужно обновить smtp_settings, если вы этого не сделали уже.
- ActionMailer::База.smtp_settings = {
- : address = > "smtp.gmail.com",
- порт => 587,
- :домен => "domain.com",
- :имя_пользователя => "user@domain.com",
- : password = > "пароль",
- : аутентификация =>: plain
- }
любые предложения для лучшего решения для разговора с Gmail будут оценены.
4 ответов
я использовал решение Александра Помозова, чтобы поговорить с Gmail из моего приложения Rails. Я считаю, что оригинальная статья ушла, но кто-то воспроизвел кеш Google здесь.
lib / 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
config / 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 (хотя он был там в течение нескольких выпусков), у меня был успех без необходимости плагинов ActionMailer для TLS, используя . Пример конфигурации (из производственной среды) выглядит следующим образом:
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, и хотя я думал (из googling around), вам не нужны плагины и требуется только строка
: enable_starttls_auto = > true,
Я на самом деле только получил его, когда я использовал решение Александра Помозова, опубликованное ski выше (большое спасибо вам, ребята). Любые комментарии по поводу почему? было бы здорово, но я просто счастлив, что это работает.