Wiem, że to stare pytanie, ale wiem też, że niektórzy ludzie są tacy jak ja i zawsze szukają aktualnych odpowiedzi , ponieważ stare odpowiedzi mogą czasami zawierać nieaktualne informacje, jeśli nie zostaną zaktualizowane.
Jest teraz styczeń 2020 i używam Django 2.2.6 i Python 3.7
Uwaga: Korzystam z DJANGO REST FRAMEWORK , poniższy kod do wysyłania e-maili był w moim widoku modeluviews.py
Po przeczytaniu wielu fajnych odpowiedzi właśnie to zrobiłem.
from django.template.loader import render_to_string
from django.core.mail import EmailMultiAlternatives
def send_receipt_to_email(self, request):
emailSubject = "Subject"
emailOfSender = "email@domain.com"
emailOfRecipient = 'xyz@domain.com'
context = ({"name": "Gilbert"}) #Note I used a normal tuple instead of Context({"username": "Gilbert"}) because Context is deprecated. When I used Context, I got an error > TypeError: context must be a dict rather than Context
text_content = render_to_string('receipt_email.txt', context, request=request)
html_content = render_to_string('receipt_email.html', context, request=request)
try:
#I used EmailMultiAlternatives because I wanted to send both text and html
emailMessage = EmailMultiAlternatives(subject=emailSubject, body=text_content, from_email=emailOfSender, to=[emailOfRecipient,], reply_to=[emailOfSender,])
emailMessage.attach_alternative(html_content, "text/html")
emailMessage.send(fail_silently=False)
except SMTPException as e:
print('There was an error sending an email: ', e)
error = {'message': ",".join(e.args) if len(e.args) > 0 else 'Unknown Error'}
raise serializers.ValidationError(error)
Ważny! Więc jak się render_to_string
dostać receipt_email.txt
i receipt_email.html
? U mnie settings.py
mam, TEMPLATES
a poniżej to, jak to wygląda
Zwróć uwagę DIRS
, jest ta linia. os.path.join(BASE_DIR, 'templates', 'email_templates')
Ta linia sprawia, że moje szablony są dostępne. W moim katalogu_projektu mam folder o nazwie templates
i podkatalog o email_templates
takiej nazwie project_dir->templates->email_templates
. Moje szablony receipt_email.txt
i receipt_email.html
znajdują się w email_templates
podkatalogu.
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR, 'templates'), os.path.join(BASE_DIR, 'templates', 'email_templates')],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]
Pozwolę sobie tylko dodać, recept_email.txt
że tak wygląda;
Dear {{name}},
Here is the text version of the email from template
I moje receipt_email.html
wygląda tak;
Dear {{name}},
<h1>Now here is the html version of the email from the template</h1>
1.7
oferty Djangohtml_message
nasend_email
stackoverflow.com/a/28476681/953553