Rails ActionMailer不在生产中发送电子邮件;没有错误

时间:2013-08-29 14:48:41

标签: ruby-on-rails actionmailer

此代码完全适用于开发,即使电子邮件具有相同的配置,电子邮件也永远不会投入生产。

配置:

  config.action_mailer.raise_delivery_errors = true
  config.action_mailer.default_url_options = { :host => 'domain.com' }
  config.action_mailer.delivery_method = :smtp
  config.action_mailer.perform_deliveries = true
  config.action_mailer.smtp_settings = {
    :address => "smtp.gmail.com",
    :port => 587,
    :authentication => :plain,
    :user_name => 'my_server@gmail.com',
    :password => 'secret',
    :enable_starttls_auto => true
  }

发送电子邮件:

logger.warn "before mail call"
logger.warn ActionMailer::Base.smtp_settings
logger.warn(mail(to: "my_email@gmail.com", subject: "Testing", body: "email body").deliver!)

服务器日志:

[2013-08-29 16:41:11.000] [WARN] -- before mail call
[2013-08-29 16:41:11.000] [WARN] -- {:address=>"smtp.gmail.com", :port=>587, :authentication=>:plain, :user_name=>"my_server@gmail.com", :password=>"secret", :enable_starttls_auto=>true}
[2013-08-29 16:41:11.000] [WARN] -- Date: Thu, 29 Aug 2013 16:41:11 +0200
From: my_server@gmail.com
To: my_email@gmail.com
Message-ID: <521f5d87537af_7af3da480050052@castillo05.fzi.de.mail>
Subject: Testing
Mime-Version: 1.0
Content-Type: text/plain;
 charset=UTF-8
Content-Transfer-Encoding: 7bit

email body

在我的localhost上开发它完美无缺。电子邮件几乎立即到达。在制作时,电子邮件永远不会到来,我没有错误。我已经尝试了很多设置组合(有/没有:enable_starttls_auto,:domain,没有设置delivery_method,perform_deliveries等),到目前为止还没有任何工作。我也试过发送到其他电子邮件但没有成功。

有什么想法吗?非常感谢提前

2 个答案:

答案 0 :(得分:0)

尝试将地址(即有效的电子邮件地址)添加到您的邮件设置中。出于这个原因,我之前收到了电子邮件。也许像admin @您的网站托管的域名?

mail(to: "my_email@gmail.com", subject: "Testing", body: "email body", from: "me@mydomainname.com").deliver!

答案 1 :(得分:0)

从您的日志判断,看起来您在代码部门正确行事。 问题可能出在您的SMTP设置中。

特别是,这篇帖子http://email.about.com/od/accessinggmail/f/Gmail_SMTP_Settings.htm说gmail的smtp端口使用的是465,我看你使用的是587。