Учебники

Джанго — Отправка электронной почты

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] мы получаем —

Отправка HTML электронной почты

Отправка электронной почты с вложением

Это делается с помощью метода 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 содержимого вложения.