Django - отправка электронной почты
Django поставляется с готовым и простым в использовании легким движком для отправки электронной почты. Как и в Python, вам просто нужен импорт smtplib. В Django вам просто нужно импортировать django.core.mail. Чтобы начать отправку электронной почты, отредактируйте файл проекта settings.py и установите следующие параметры:
EMAIL_HOST - smtp сервер.
EMAIL_HOST_USER - Учетные данные для входа на SMTP-сервер.
EMAIL_HOST_PASSWORD - Учетные данные пароля для SMTP-сервера.
EMAIL_PORT - порт smtp сервера.
EMAIL_USE_TLS or _SSL - Верно, если соединение защищено.
Отправка простого электронного письма
Давайте создадим представление sendSimpleEmail для отправки простого электронного письма.
from django.core.mail import send_mail
from django.http import HttpResponse
def sendSimpleEmail(request,emailto):
res = send_mail("hello paul", "comment tu vas?", "[email protected]", [emailto])
return HttpResponse('%s'%res)
Вот подробности параметров send_mail -
subject - Тема электронного письма.
message - Тело электронной почты.
from_email - Электронная почта от.
recipient_list - Список адресов электронной почты получателей.
fail_silently - Bool, если false, send_mail вызовет исключение в случае ошибки.
auth_user - Логин пользователя, если он не задан в settings.py.
auth_password - Пароль пользователя, если он не задан в settings.py.
connection - Бэкэнд электронной почты.
html_message - (новое в Django 1.7), если есть, электронное письмо будет составным / альтернативным.
Давайте создадим URL-адрес для доступа к нашему представлению -
from django.conf.urls import patterns, url
urlpatterns = paterns('myapp.views', url(r'^simpleemail/(?P<emailto>
[\w.%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,4})/',
'sendSimpleEmail' , name = 'sendSimpleEmail'),)
Итак, при доступе к /myapp/simpleemail/[email protected] вы получите следующую страницу -
Отправка нескольких писем с помощью send_mass_mail
Метод возвращает количество успешно доставленных сообщений. То же, что и send_mail, но требует дополнительного параметра; datatuple, тогда наше представление sendMassEmail будет -
from django.core.mail import send_mass_mail
from django.http import HttpResponse
def sendMassEmail(request,emailto):
msg1 = ('subject 1', 'message 1', '[email protected]', [emailto1])
msg2 = ('subject 2', 'message 2', '[email protected]', [emailto2])
res = send_mass_mail((msg1, msg2), fail_silently = False)
return HttpResponse('%s'%res)
Давайте создадим URL-адрес для доступа к нашему представлению -
from django.conf.urls import patterns, url
urlpatterns = paterns('myapp.views', url(r'^massEmail/(?P<emailto1>
[\w.%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,4})/(?P<emailto2>
[\w.%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,4})', 'sendMassEmail' , name = 'sendMassEmail'),)
При доступе к /myapp/massemail/[email protected]/[email protected]/ мы получаем -
Детали параметров send_mass_mail -
datatuples - Кортеж, в котором каждый элемент похож (тема, сообщение, from_email, список получателей).
fail_silently - Bool, если false, send_mail вызовет исключение в случае ошибки.
auth_user - Логин пользователя, если он не задан в settings.py.
auth_password - Пароль пользователя, если он не задан в settings.py.
connection - Бэкэнд электронной почты.
Как вы можете видеть на изображении выше, два сообщения были отправлены успешно.
Note - В этом примере мы используем сервер отладки Python smtp, который вы можете запустить с помощью -
$python -m smtpd -n -c DebuggingServer localhost:1025
Это означает, что все отправленные вами электронные письма будут напечатаны на stdout, а фиктивный сервер работает на localhost: 1025.
Sending e-mails to admins and managers using mail_admins and mail_managers methods
Эти методы отправляют электронные письма администраторам сайта, как определено в параметре ADMINS файла settings.py, и менеджерам сайта, как определено в параметре MANAGERS файла settings.py. Предположим, наши параметры ADMINS и MANAGERS выглядят так -
ADMINS = (('поло', 'поло@polo.com'),)
MANAGERS = (('popoli', '[email protected]'),)
from django.core.mail import mail_admins
from django.http import HttpResponse
def sendAdminsEmail(request):
res = mail_admins('my subject', 'site is going down.')
return HttpResponse('%s'%res)
Приведенный выше код отправит электронное письмо каждому администратору, указанному в разделе ADMINS.
from django.core.mail import mail_managers
from django.http import HttpResponse
def sendManagersEmail(request):
res = mail_managers('my subject 2', 'Change date on the site.')
return HttpResponse('%s'%res)
Приведенный выше код отправит электронное письмо каждому менеджеру, указанному в разделе МЕНЕДЖЕРЫ.
Детали параметров -
Subject - Тема электронного письма.
message - Тело электронной почты.
fail_silently - Bool, если false, send_mail вызовет исключение в случае ошибки.
connection - Бэкэнд электронной почты.
html_message - (новое в Django 1.7), если есть, электронное письмо будет составным / альтернативным.
Отправка электронного письма в формате HTML
Отправить HTML-сообщение в Django> = 1.7 так же просто, как -
from django.core.mail import send_mail
from django.http import HttpResponse
res = send_mail("hello paul", "comment tu vas?", "[email protected]",
["[email protected]"], html_message=")
Это создаст составное / альтернативное электронное письмо.
Но для Django <1.7 отправка HTML-сообщений выполняется через класс django.core.mail.EmailMessage, а затем вызывается send для объекта -
Давайте создадим представление sendHTMLEmail для отправки электронной почты в формате HTML.
from django.core.mail import EmailMessage
from django.http import HttpResponse
def sendHTMLEmail(request , emailto):
html_content = "<strong>Comment tu vas?</strong>"
email = EmailMessage("my subject", html_content, "[email protected]", [emailto])
email.content_subtype = "html"
res = email.send()
return HttpResponse('%s'%res)
Подробные сведения о параметрах для создания класса EmailMessage -
Subject - Тема электронного письма.
message - Текст сообщения электронной почты в формате HTML.
from_email - Электронная почта от.
to - Список адресов электронной почты получателей.
bcc - Список адресов электронной почты получателей «скрытой копии».
connection - Бэкэнд электронной почты.
Давайте создадим URL-адрес для доступа к нашему представлению -
from django.conf.urls import patterns, url
urlpatterns = paterns('myapp.views', url(r'^htmlemail/(?P<emailto>
[\w.%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,4})/',
'sendHTMLEmail' , name = 'sendHTMLEmail'),)
При доступе к /myapp/htmlemail/[email protected] мы получаем -
Отправка электронной почты с вложением
Это делается с помощью метода «прикрепить» к объекту EmailMessage.
Вид для отправки электронного письма с вложением будет -
from django.core.mail import EmailMessage
from django.http import HttpResponse
def sendEmailWithAttach(request, emailto):
html_content = "Comment tu vas?"
email = EmailMessage("my subject", html_content, "[email protected]", emailto])
email.content_subtype = "html"
fd = open('manage.py', 'r')
email.attach('manage.py', fd.read(), 'text/plain')
res = email.send()
return HttpResponse('%s'%res)
Подробная информация о прикрепленных аргументах -
filename - Имя прикрепляемого файла.
content - Содержимое прикрепляемого файла.
mimetype - Тип MIME содержания прикрепленного файла.