5

Django 项目settings.py包括以下内容:

EMAIL_BACKEND = "django.core.mail.backends.smtp.EmailBackend"
EMAIL_HOST = "smtp.gmail.com"
EMAIL_HOST_USER = "you.cant.see.me@gmail.com"
EMAIL_HOST_PASSWORD = "thug_life"
EMAIL_PORT = 587
EMAIL_USE_TLS = True

我的应用程序views.py包含以下内容

def send_classic_email(request):
    from django.core.mail import send_mail
    send_mail(
        subject = "Tale of two cities",
        from_email = "Charles Dickens <you.cant.see.me@gmail.com>",
        recipient_list = ["someone@example.com"],
        message = "There were 2 cities",
        html_message = "<p>There were 2 cities</p>",
        fail_silently = False,
    )
    print "Absolutely Perfectly Done"

从本地主机尝试。得到SMTPAuthenticationError回报:

SMTPAuthenticationError at /send_classic_email/
(534, '1.3.95 <https://accounts.google.com/ContinueSignIn?sarp=1&scc=1&plt=fsadjSADJH\n1.3.95 
fjkshFHAKSHkdfshkfkhj-sfjdhFsadASDA_\n1.3.95 
dasdASDADas-aDas-hfhjsadASDSAhjjhd\n1.3.95 
ADSaSADkja_adhjkADKjhads-ASADS_SDAKjadAKJhsADS-k\n1.3.95 
sadhkjADSAKJSDJAlkjdaA> Please log in via your web browser and\n1.3.95 
then try again.\n1.3.95  
Learn more at\n1.3.95  
https://support.google.com/mail/answer/78754 dkahASDASlkjdas.25 - gsmtp')

然后访问https://www.google.com/settings/security/lesssecureapps并启用该less secure app设置。

之后,从 localhost 再次尝试。收到:

绝对完美完成

在 AWS EC2 上部署了这段代码。从 EC2 尝试过。再次得到同样的结果SMTPAuthenticationError

SMTPAuthenticationError at /send_classic_email/
(534, '1.3.95 <https://accounts.google.com/ContinueSignIn?sarp=1&scc=1&plt=fsadjSADJH\n1.3.95 
fjkshFHAKSHkdfshkfkhj-sfjdhFsadASDA_\n1.3.95 
dasdASDADas-aDas-hfhjsadASDSAhjjhd\n1.3.95 
ADSaSADkja_adhjkADKjhads-ASADS_SDAKjadAKJhsADS-k\n1.3.95 
sadhkjADSAKJSDJAlkjdaA> Please log in via your web browser and\n1.3.95 
then try again.\n1.3.95  
Learn more at\n1.3.95  
https://support.google.com/mail/answer/78754 dkahASDASlkjdas.25 - gsmtp')

前往 EC2 安全组:

  • 已启用来自所有来源的SMTP 端口的入站规则。
  • 为通过所有协议所有目标的所有端口的所有流量的出站规则启用。

还是一样SMTPAuthenticationError

为什么它在 localhost 而不是 EC2 实例上运行良好?

继续运行Django 1.8.0_Python 2.7.6Ubuntu 14.04.3 LTS

4

2 回答 2

16

您可能需要解锁验证码以使 Django 为您发送:accounts.google.com/displayunlockcaptcha

验证码是您需要在表单中输入才能进入下一页的小字符。这是大多数公司依赖的安全预防措施。

您能够在本地主机上逃脱它的原因是因为您本质上是控制验证码的公司。您是在告诉您的服务器,“无论如何都发送;它是安全的。” 但是,在这种情况下,Google 控制着验证码。由于您使用的是亚马逊,因此阻止电子邮件是谷歌保护其服务器并确保亚马逊不是垃圾邮件的一种方式。通过单击该链接,您是在告诉 Google 允许通过您的电子邮件进行所有传出连接。

那有意义吗?

于 2016-02-27T17:08:16.067 回答
1

我有一种感觉亚马逊不允许这样做。他们真的不希望您从他们的服务器发送邮件,所以他们阻止了它。基本上,这是为了避免垃圾邮件发送者,他们过去常常通过虚拟卡车从 EC2 发送电子邮件。我建议您使用类似 mailgun(或 SES,如果您真的喜欢 AWS,但我可能不会)来处理发送电子邮件。mailgun有一个不错的django 电子邮件后端,因此您根本不需要更改代码。

于 2016-02-26T20:56:32.637 回答