Rails邮件程序不发送

时间:2017-11-21 11:20:03

标签: ruby-on-rails ruby email gmail actionmailer

我正在尝试通过我的Rails应用程序发送'密码重置'邮件。但问题是电子邮件永远不会到达,尽管我的日志说它已发送。

这是config / environments / development.rb中的配置

config.action_mailer.delivery_method = :smtp
  config.action_mailer.smtp_settings = {
      address:              'smtp.gmail.com',
      port:                 587,
      user_name:            'xxxxx@gmail.com',
      password:             'yyyyy',
      authentication:       'plain',
      enable_starttls_auto: true  }

我的app / mailers / user_mailer.rb:

class UserMailer < ActionMailer::Base
  default from: "xxxxx@gmail.com"

  def password_reset(user)
    @user = user
    mail :to => user.email, :subject => "Password Reset"
  end
end

在app / models / user.rb中调用邮件程序的方法

def send_password_reset
    generate_token(:password_reset_token)
    self.password_reset_sent_at = Time.zone.now
    save!(:validate => false)
    UserMailer.password_reset(self).deliver_now
  end

视图和一切都很好,因为正如我所说,日志说电子邮件已成功发送,我猜想我必须缺少一些配置。这是日志:

Sent mail to zzzzz@hotmail.com (2007.7ms)
Date: Tue, 21 Nov 2017 12:10:46 +0100
From: xxxxx@gmail.com
To: zzzzz@hotmail.com
Message-ID: <5a1409b627bb8_3ca86e9450429578@DESKTOP-85KSOM4.mail>
Subject: Password Reset
Mime-Version: 1.0
Content-Type: text/plain;
 charset=UTF-8
Content-Transfer-Encoding: quoted-printable

Sigue el siguiente enlace para restablecer la contrase=C3=B1a
http://localhost:3000/password_resets/w0F77qrpHbM9HvXaFElWGA/edit
Ignora este email si no pediste el cambio.

Redirected to http://localhost:3000/

此外,发件人Gmail的发件箱是空的,但我允许不太安全的应用程序访问我的Gmail帐户,所以问题必须是另一回事。我不知道如何调试出错的地方。

2 个答案:

答案 0 :(得分:1)

似乎连接被拒绝了。重新启动服务器解决了这个问题。

答案 1 :(得分:0)

为了更好的邮件调试,您可以尝试使用bang方法deliver_now!,看看它是否会引发任何异常(例如密码问题)。

  

方法:ActionMailer :: MessageDelivery#deliver_now!

     

定义于:       actionmailer / lib / action_mailer / message_delivery.rb

     

deliver_now! ⇒对象

     

发送电子邮件而不检查perform_deliveries和   raise_delivery_errors,请谨慎使用。

     

Notifier.welcome(User.first).deliver_now!