为什么 django send_mail 无法无错误地发送电子邮件?

Hsn*_*edi 3 django gmail smtp sendmail wagtail

我想在 django 中使用 send_mail,但它不发送任何电子邮件。这是我的设置:

EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
EMAIL_HOST = 'smtp.gmail.com'
EMAIL_HOST_USER = 'MY-GMAIL-USERNAME@gmail.com'
EMAIL_HOST_PASSWORD = 'MY-GMAIL-PASSWORD'
EMAIL_PORT = 465
EMAIL_USE_TLS = False
EMAIL_USE_SSL = True
DEFAULT_FROM_EMAIL = EMAIL_HOST_USER
SERVER_EMAIL = DEFAULT_FROM_EMAIL
Run Code Online (Sandbox Code Playgroud)

然后,我运行python manage.py shell

from django.conf import settings
from django.core.mail import send_mail

subject = 'Test Subject'
message = 'Test Message'
email_from = settings.EMAIL_HOST_USER
recipient_list = ['MY-YAHOO-USERNAME@yahoo.com']
send_mail(subject, message, email_from, recipient_list, fail_silently=False)
Run Code Online (Sandbox Code Playgroud)

它不发送电子邮件,而是打印:

Content-Type: text/plain; charset="utf-8"
MIME-Version: 1.0
Content-Transfer-Encoding: 7bit
Subject: Test Subject
From: MY-GMAIL-USERNAME@gmail.com
To: MY-YAHOO-USERNAME@yahoo.com
Date: Mon, 09 Dec 2019 21:02:16 -0000
Message-ID: <157592533640.18842.5494330274157836181@thinkpad-e560>

Test Message
-------------------------------------------------------------------------------
1
Run Code Online (Sandbox Code Playgroud)

这似乎没有错误。为什么它不发送电子邮件?怎么了?为什么它不记录任何错误?

此页面之后,我尝试了一种纯 python 方式,它工作正常:

import smtplib, ssl

smtp_server = "smtp.gmail.com"
port = 465
sender_email = "MY-GMAIL-USERNAME@gmail.com"
password = 'MY-GMAIL-PASSWORD'
receiver_email = 'MY-YAHOO-USERNAME@yahoo.com'
context = ssl.create_default_context()
server = smtplib.SMTP_SSL("smtp.gmail.com", port, context=context)
server.login(sender_email, password)
server.sendmail(sender_email, receiver_email, 'Test Message')
Run Code Online (Sandbox Code Playgroud)

正如我所提到的,这种纯 python 方式工作正常!我糊涂了。

我做错了什么?

Hsn*_*edi 6

感谢@IainShelvington 和@ivissani,我已经弄明白了。我在 django 之上使用 wagtail cms 并使用“wagtail start mysite”创建了该项目。有关更多信息,请参阅

在wagtail标准项目结构中,有base.py、dev.py和production.py,而不是settings.py。

电子邮件设置在 base.py 中,但在 dev.py 中,EMAIL_BACKEND 被覆盖。这是使用 wagtail 创建 django 项目时的 dev.py:

from .base import *

# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True

# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = 'MY-SITE-KEY'

# SECURITY WARNING: define the correct hosts in production!
ALLOWED_HOSTS = ['*'] 

EMAIL_BACKEND = 'django.core.mail.backends.console.EmailBackend'


try:
    from .local import *
except ImportError:
    pass
Run Code Online (Sandbox Code Playgroud)

所以我通过从 dev.py 中删除 EMAIL_BACKEND 解决了这个问题