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 или _SSL — True, если безопасное соединение.
EMAIL_HOST — сервер smtp.
EMAIL_HOST_USER — учетные данные для входа на сервер SMTP.
EMAIL_HOST_PASSWORD — Учетные данные для пароля для сервера SMTP.
EMAIL_PORT — порт сервера smtp.
EMAIL_USE_TLS или _SSL — True, если безопасное соединение.
Отправка простого электронного письма
Давайте создадим представление «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 —
-
тема — тема электронной почты.
-
сообщение — E-mail body.
-
from_email — электронная почта от.
-
receient_list — Список адресов электронной почты получателей.
-
fail_silently — Bool, если false send_mail вызовет исключение в случае ошибки.
-
auth_user — Логин пользователя, если он не установлен в settings.py.
-
auth_password — пароль пользователя, если он не установлен в settings.py.
-
соединение — E-mail backend.
-
html_message — (новое в Django 1.7), если оно присутствует, электронное письмо будет составным / альтернативным.
тема — тема электронной почты.
сообщение — E-mail body.
from_email — электронная почта от.
receient_list — Список адресов электронной почты получателей.
fail_silently — Bool, если false send_mail вызовет исключение в случае ошибки.
auth_user — Логин пользователя, если он не установлен в settings.py.
auth_password — пароль пользователя, если он не установлен в settings.py.
соединение — E-mail backend.
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 — кортеж, в котором каждый элемент похож (тема, сообщение, от_почты, список получателей).
-
fail_silently — Bool, если false send_mail вызовет исключение в случае ошибки.
-
auth_user — Логин пользователя, если он не установлен в settings.py.
-
auth_password — пароль пользователя, если он не установлен в settings.py.
-
соединение — E-mail backend.
datatuples — кортеж, в котором каждый элемент похож (тема, сообщение, от_почты, список получателей).
fail_silently — Bool, если false send_mail вызовет исключение в случае ошибки.
auth_user — Логин пользователя, если он не установлен в settings.py.
auth_password — пароль пользователя, если он не установлен в settings.py.
соединение — E-mail backend.
Как вы можете видеть на изображении выше, два сообщения были успешно отправлены.
Примечание. В этом примере мы используем Python smtp debuggingserver, который вы можете запустить с помощью —
$python -m smtpd -n -c DebuggingServer localhost:1025
Это означает, что все отправленные вами электронные письма будут напечатаны на stdout, а фиктивный сервер работает на localhost: 1025.
Отправка электронной почты администраторам и менеджерам с помощью методов mail_admins и mail_manager
Эти методы отправляют электронные письма администраторам сайта, как определено в параметре ADMINS файла settings.py, и менеджерам сайта, как определено в параметре MANAGERS файла settings.py. Давайте предположим, что наши параметры ADMINS и MANAGERS выглядят так:
ADMINS = ((‘polo’, ‘[email protected]’),)
МЕНЕДЖЕРЫ = ((«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)
Приведенный выше код отправит электронное письмо каждому менеджеру, указанному в разделе МЕНЕДЖЕРЫ.
Параметры детали —
-
Тема — тема электронной почты.
-
сообщение — E-mail body.
-
fail_silently — Bool, если false send_mail вызовет исключение в случае ошибки.
-
соединение — E-mail backend.
-
html_message — (новое в Django 1.7), если оно присутствует, электронное письмо будет составным / альтернативным.
Тема — тема электронной почты.
сообщение — E-mail body.
fail_silently — Bool, если false send_mail вызовет исключение в случае ошибки.
соединение — E-mail backend.
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 —
-
Тема — тема электронной почты.
-
сообщение — тело письма в HTML.
-
from_email — электронная почта от.
-
to — Список адресов электронной почты получателей.
-
bcc — Список адресов электронной почты получателей «Bcc».
-
соединение — E-mail backend.
Тема — тема электронной почты.
сообщение — тело письма в HTML.
from_email — электронная почта от.
to — Список адресов электронной почты получателей.
bcc — Список адресов электронной почты получателей «Bcc».
соединение — E-mail backend.
Давайте создадим 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] мы получаем —
Отправка электронной почты с вложением
Это делается с помощью метода attach в объекте 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 содержимого вложения.