Получение "сначала необходимо выполнить команду STARTTLS" при попытке отправить электронное письмо

Я получаю ошибку при попытке использовать action_mailer_tls плагин для связи с Gmail в моем приложении Rails:

Must issue a STARTTLS command first

другие, кажется, столкнулись эта же проблема:

проблема в том, что Gmail требует TLS аутентификация, но стандартный Ruby библиотека net / smtp не поддерживает TLS.

статьи рекомендует следующие шаги, которые я сделал:

конечно есть полезный плагин создано Marc Chung для преодоления этого барьер. Вы можете найти его здесь и вручную добавить его в свой проект или вы может экспортировать его в свой плагин справочник.

  1. $ cd vendor/plugins
  2. $ svn export http://code.openrain.com/rails/action_mailer_tls/

в любом случае убедитесь, что вы требуете 'smtp_tls'

теперь все, что вам нужно обновить smtp_settings, если вы этого не сделали уже.

  1. ActionMailer::База.smtp_settings = {
  2. : address = > "smtp.gmail.com",
  3. порт => 587,
  4. :домен => "domain.com",
  5. :имя_пользователя => "user@domain.com",
  6. : password = > "пароль",
  7. : аутентификация =>: plain
  8. }

любые предложения для лучшего решения для разговора с 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 выше (большое спасибо вам, ребята). Любые комментарии по поводу почему? было бы здорово, но я просто счастлив, что это работает.