Получение & # 8220; Сначала необходимо выполнить команду STARTTLS & # 8221; при попытке отправить письмо

StackOverflow https://stackoverflow.com/questions/1641354

  •  08-07-2019
  •  | 
  •  

Вопрос

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

Must issue a STARTTLS command first

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

  

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

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

  

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

     <Ол>   
  • $ cd vendor / plugins
  •   
  • $ svn export http://code.openrain.com/rails/action_mailer_tls/
  •         

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

         

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

         <Ол>   
  • ActionMailer :: Base.smtp_settings = {
  •   
  • : address = > " smtp.gmail.com " ;,
  •   
  • : port = > 587,
  •   
  • : domain = > " domain.com " ;,
  •   
  • : user_name = > " user@domain.com" ;,
  •   
  • : пароль = > " пароль " ;,
  •   
  • : аутентификация = > : обычный
  •   <Литий>}   

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

    Это было полезно?

    Решение

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

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

    Лицензировано под: CC-BY-SA с атрибуция
    Не связан с StackOverflow
    scroll top