サイトアイコン ITC Media

【徹底解説】Django send_mailの使い方|初心者向け

(最終更新月:2022年8月)

✔このような方へ向けて書かれた記事となります

「Djangoのsend_mailを使いたい!」

「Djangoでメール送信の実装がしたい!」

「メール送信実装について実例が見たい!」

✔当記事を通じてお伝えすること

当記事を最後までお読みいただければ、Djangoのsend_mailメソッドの使い方がわかるのはもちろん、ほかにもメールを送る方法があり、それぞれの特徴も理解できます

筆者プロフィール

【現職】プロダクトマネージャー

【副業】ブログ(月間20万PV)/YouTube/Web・アプリ制作

「プログラミング × ライティング × 営業」の経験を活かし、30後半からのIT系職へシフト。現在はプロダクトマネージャーとして、さまざまな関係者の間に入り奮闘してます。当サイトでは、実際に手を動かせるWebアプリの開発を通じて、プログラミングはもちろん、IT職に必要な情報を提供していきます。

【当ブログで紹介しているサイト】

当サイトチュートリアルで作成したデモ版日報アプリ

Django × Reactで開発したツール系Webアプリ

✔人に見せても恥ずかしくないコードを書こう

「リーダブルコード」は、わかりやすく良いコードの定義を教えてくれる本です。

  • 見るからにきれいなコードの書き方
  • コードの分割方法
  • 変数や関数の命名規則

エンジニアのスタンダートとすべき基準を一から解説しています。

何回も読むのに値する本なので、ぜひ手にとって読んでみてください。

Djangoでメール送信実装の事前準備

Djangoでメール送信を実装するには事前に準備が必要です。

以下の3つがおおまかな流れになります。

それぞれ見ていきましょう。

メール送信のための設定

メール送信の実装方法は2通りあります。

  1. 機能確認のためにローカルコンソールに表示する
  2. 実際にメールを送る設定をする

もし機能だけ確認したいなら、まずはコンソールに表示する方法で充分です。

settings.pyに、以下の通り記述します。

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

詳しくはこちらでも解説しています。

実際にメールを送信したいなら、以下のようにします。

EMAIL_HOST = 'SMTPサーバー情報'
EMAIL_HOST_USER = 'デフォルトのEmailアドレス'
EMAIL_HOST_PASSWORD = 'メールサーバーのパスワード'
EMAIL_PORT = '465' #メールサーバーで指定されているポート
EMAIL_USE_SSL = True #メールサーバーで確認(TSLの場合もある)
DEFAULT_FROM_EMAIL = '任意のメールアドレス'

具体例を見てみたい方は、以下の記事を参考にして下さい。

送信ページの作成

送信ページは、主に以下の3つのファイルにコードを書きます

一例としてコンタクトフォームを実際に作ったので、コードも含めてご覧ください。

送信のための関数作り

送信のための関数は複数存在します。

それぞれ特徴が違いますので、使いやすいものを見つけられるよう次章で詳しくご紹介します。

Djangoで使えるメール送信メソッド5選

send_mailはもちろん、Djangoではよく使われるメール送信のためのメソッドが5つあります。

以下のとおりです。

ひとつずつ見ていきましょう。

send_mail

send_mailメソッドは一番ベーシックなメール送信方法だといえるでしょう。

send_mailでは、引数として以下の4つが必要です。

具体例を見ていただくと下記のとおりです。

from django.core.mail import send_mail

subject = "サンプルメールのタイトル"
message = "サンプルメールの本文です"
from_email = "admin@itc.tokyo"
recipient_list =["test@itc.tokyo"]

send_mail(subject, message, from_email, recipient_list)

EmailMessage

EmailMessageクラスは、send_mailの項目に加えて、bccが追加できるメリットがあります。

具体例は以下のとおりです。

from django.core.mail import EmailMessage

subject = "サンプルメールのタイトル"
message = "サンプルメールの本文です"
from_email = "admin@itc.tokyo"
recipient_list =["test@itc.tokyo"]
bcc = ["test-bcc@itc.tokyo"]

msg = EmailMessage(subject, message, from_email, recipient_list, bcc)
msg.send()

EmailMessageはクラスなので、インスタンスを作る必要があります

インスタンスのsendメソッドで送信できます。

mail_admins

mail_adminsメソッドは、送信先が管理者となっているメール送信メソッドです。

mail_adminsのメリットは、以下の2つだけあれば管理者宛にメールが送れること。

ただし、管理者情報をsettings.pyで設定しておく必要があります。

#ADMINS = [(名前, Eメールアドレス)]
#例
ADMINS = [('admin', 'admin@itc.tokyo')]

設定が完了していれば、以下のコードでメール送信可能です。

from django.core.mail import mail_admins

subject = "サンプルメールのタイトル"
message = "サンプルメールの本文です"

mail_admins(subject, message)

メールの送信元は、「root@localhost」となります。

EmailMultiAlternatives

EmailAlternativesクラスは、テキストメールだけでなく、HTMLメールを送りたいときに使えるメソッドです。

本文をテキストメール用とHTMLメール用に分けて渡すことで、受け取り側の状況に合わせたメールとなります。

具体例は以下のようになります。

from django.core.mail import EmailMultiAlternatives

subject = "サンプルメールのタイトル"
text_content = "サンプルメールの本文です"
html_content = "<h1>サンプルメールの本文です</h1>"
from_email = "admin@itc.tokyo"
recipient_list =["test@itc.tokyo"]

msg = EmailMultiAlternatives(subject, text_content, from_email, recipient_list)
msg.attach_alternative(html_content, "text/html")
msg.send()

一度インスタンスを作ってから、attach_alternativeメソッドで追加するのがポイントです。

詳しくは以下の記事でも解説していますので、ご覧ください。

email_user

email_userは、ユーザーインスタンスに備わっていて、ユーザーインスタンスに登録されているEメールアドレスに送信するメソッドです。

つまりadminユーザーで「email_user」メソッドを実行すれば、宛先を指定せずともadminユーザーにメールが送られるということになります。

指定すべき引数は以下の3つです。

具体例は以下のとおりとなります。

subject = "サンプルメールのタイトル"
message = "サンプルメールの本文です"
from_email = "admin@itc.tokyo"      
 
if request.user.is_authenticated:
    request.user.email_user(subject, message, from_email)
else:
    print("ログインユーザーでなければメールは送れません")

記載の通りログインユーザーでなければ送れないので、該当ページにはログイン制限などを設定しておく必要があるかもしれません。

【応用編】テキストファイル(テンプレート)を使った送信方法

Djangoのメール送信機能には、テキストファイルなどをテンプレートとした送信方法も存在します。

たとえば以下のようなテンプレートファイルを用意します。

プロジェクトフォルダ > アプリフォルダ > mail_templates > sample.txt

{{ user.username }}様

氏名:{{ user.first_name }} {{ user.last_name }}
メールアドレス: {{ user.email }}
問い合わせ内容
{{ message }}

{% if user.is_superuser %}
    >>> 管理者向けのメールです。<<<
{% endif %}

send_mailメソッドを使って、実装すると以下のようになります。

from django.core.mail import send_mail
from django.template.loader import render_to_string
from django.conf import settings

subject = "サンプルメールのタイトル"
message = "サンプルメールの本文です"
from_email = "admin@itc.tokyo"
recipient_list =["test@itc.tokyo"]

ctx = {
    "user": request.user,
    "message": message
}

msg = render_to_string(f"{settings.BASE_DIR}/アプリフォルダ/mail_templates/sample.txt", ctx, request)

send_mail(subject, msg, from_email, recipient_list)

メールのパターンをいくつか用意している場合はとても便利ですね!

まとめ:Djangoのメール送信メソッドを特徴で使いわけよう

当記事の内容をまとめます。

ご紹介したDjangoのメール送信メソッドは以下の5つでした。

  1. send_mail
  2. EmailMessage
  3. mail_admins
  4. EmailMultiAlternatives
  5. email_user

それぞれの特徴を理解すれば無駄なく、メール送信の実装が可能です。

今回はメール送信のためのメソッドに注目しましたが、実際にメールを送りたい方は以下の記事も参考にして下さい。

モバイルバージョンを終了