Получение «Сначала необходимо выполнить команду STARTTLS» при попытке отправить электронное письмо - PullRequest
7 голосов
/ 29 октября 2009

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

Must issue a STARTTLS command first

Другие, похоже, сталкивались с этой же проблемой :

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

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

Конечно, есть полезный плагин созданный Марком Чангом, чтобы преодолеть это барьер. Вы можете найти это здесь и вручную добавьте его в свой проект или вы можете экспортировать его в свой плагин каталог.

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

В любом случае убедитесь, что вам требуется 'Smtp_tls'

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

  1. ActionMailer :: Base.smtp_settings = {
  2. : address => "smtp.gmail.com",
  3. : порт => 587,
  4. : domain => "domain.com",
  5. : user_name => "user@domain.com",
  6. : пароль => "пароль",
  7. : аутентификация =>: обычная
  8. }

Буду признателен за любые предложения по лучшему решению для общения с Gmail.

Ответы [ 4 ]

10 голосов
/ 29 октября 2009

Я использовал решение Александра Помозова, чтобы общаться с 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 как обычно.

5 голосов
/ 29 октября 2009

С 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"
}
1 голос
/ 18 декабря 2015

Я включил starttls, используя :enable_starttls_auto => true, но все равно получил ту же ошибку. Наконец-то я смог решить эту проблему без единого изменения в коде. Если вы используете smtp.gmail.com для отправки почты, вы должны сначала разрешить менее безопасным приложениям использовать вашу электронную почту для отправки почты. Для этого войдите под своей учетной записью, с которой вы хотите отправлять почту, и перейдите на эта ссылка и включают доступ к менее защищенным приложениям.
Изменить: Если вам не разрешено изменять настройки менее защищенных приложений, обратитесь к владельцу учетной записи администратора этого домена, чтобы изменить настройки, чтобы пользователи могли использовать менее защищенные приложения.
Если у вас есть права администратора, вы можете разрешить пользователям изменять свои менее безопасные настройки приложения, вы можете изменить его с https://admin.google.com/domainname.com/AdminHome#ServiceSettings/notab=1&service=securitysetting&subtab=lesssecureappsaccess
PS: не забудьте изменить доменное имя в приведенной выше ссылке.

Надеюсь, это хепс !!

0 голосов
/ 06 декабря 2009

Я запускаю рельсы 2.3.4, и хотя я думал (из-за прибегая к помощи), вам не потребуются никакие плагины, а только строка

: enable_starttls_auto => true,

На самом деле я получил его на работу, только когда использовал решение Александра Помозова, опубликованное на лыже выше (большое спасибо вам, ребята). Есть комментарии, почему? было бы здорово, но я просто счастлив, что это работает.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...