Django使用SMTP发送邮件教程

CONTENTS

    • [1. SMTP介绍](#1. SMTP介绍)
    • [2. 申请邮箱授权码](#2. 申请邮箱授权码)
    • [3. Django发送邮件](#3. Django发送邮件)

1. SMTP介绍

SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP 协议属于 TCP/IP 协议簇,它帮助每台计算机在发送或中转信件时找到下一个目的地。通过 SMTP 协议所指定的服务器,就可以把 E-mail 寄到收信人的服务器上了,整个过程只要几分钟。SMTP 服务器则是遵循 SMTP 协议的发送邮件服务器,用来发送或中转发出的电子邮件。

一个 SMTP 服务器总是有一个独特的地址,和一个用于发送邮件的特定端口,在大多数情况下是587。本文以使用 QQ 邮箱为例,因此我们将使用的地址是 smtp.qq.com,端口号是587。

2. 申请邮箱授权码

首先我们需要启用 QQ 邮箱的 SMTP 服务,并申请一个授权码,打开邮箱网页,然后在"设置-账号"选项卡中找到 SMTP 服务部分,点击开启服务:

进行相关的身份验证后会收到一串授权码如下:

3. Django发送邮件

首先在项目的 settings.py 文件中添加配置信息:

py 复制代码
EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
EMAIL_HOST = 'smtp.qq.com'
EMAIL_PORT = 587
EMAIL_USE_TLS = True
EMAIL_HOST_USER = '******@qq.com'
EMAIL_HOST_PASSWORD = '******'

RECIPIENT_ADDRESS = ['******@qq.com']

配置参数说明如下:

  • EMAIL_BACKEND:声明了我们的 Django 项目将用于连接 SMTP 服务器的后端。这个变量指向 smtp.EmailBackend 类,该类接收发送邮件所需的所有参数。虽然这个类是默认的 EMAIL_BACKEND,但在 Django 的设置中明确定义被认为是一个好的做法。
  • EMAIL_HOST:将要使用的 SMTP 服务器域,取决于你的电子邮件提供商。常用的有:smtp.qq.comsmtp.163.comsmtp.gmail.com 等。
  • EMAIL_PORT:SMTP 服务器端口号,587是大多数 SMTP 服务器的默认端口,对于个人电子邮件提供商来说,这一点仍然适用。
  • EMAIL_USE_TLS:TLS(Transport Layer Security,传输层安全协议),用于在两个应用程序之间提供保密性和数据完整性。在此处用于加密网络应用程序(Django)和服务器(SMTP 服务器)之间的通信。
  • EMAIL_HOST_USER:主机用户(发件人邮箱),设置是你的个人电子邮件地址。
  • EMAIL_HOST_PASSWORD:发件人的授权码,即从你的电子邮件帐户获得的应用程序密码。
  • RECIPIENT_ADDRESS:收件人邮箱列表。

现在假设我们的前端发来如下请求:

js 复制代码
$.ajax({
    url: 'http://localhost:8000/sendemail/',
    type: 'GET',
    data: {
        message: message,
    },
    dataType: 'json',
    success: (resp) => {
        ...
    }
});

然后我们需要在后端接收 message,并将其通过邮件(django.core.mail.send_mail 函数)发送给自己(即 settings 中的 EMAIL_HOST_USER 为自己的邮箱,RECIPIENT_ADDRESS 列表中也仅有一个自己的邮箱):

py 复制代码
from django.http import JsonResponse
from django.core import mail
from django.conf import settings

def sendEmail(request):
    data = request.GET
    message = data.get('message', '').strip()  # 如果没有的话返回空,且过滤掉空格

    if message:
        mail.send_mail(
            subject='在线计算器与编译器项目用户反馈',  # 题目
            message=message,  # 消息内容
            from_email=settings.EMAIL_HOST_USER,  # 发送者
            recipient_list=settings.RECIPIENT_ADDRESS,  # 接收者邮件列表
        )

    return JsonResponse({
        'result': 'success',
    })
相关推荐
该用户已不存在7 分钟前
Vibe Coding 入门指南:从想法到产品的完整路径
前端·人工智能·后端
不剪发的Tony老师11 分钟前
SQL Schema Compare:一款免费开源的数据库结构比较和同步工具
数据库
申阳13 分钟前
Day 3:01. 基于Nuxt开发个人呢博客项目-初始化项目
前端·后端·程序员
铁锹少年14 分钟前
当多进程遇上异步:一次 Celery 与 Async SQLAlchemy 的边界冲突
分布式·后端·python·架构·fastapi
梨轻巧16 分钟前
pyside6常用控件:QCheckBox() 单个复选框、多个复选框、三态模式
python
寒秋丶21 分钟前
Milvus:集合(Collections)操作详解(三)
数据库·人工智能·python·ai·ai编程·milvus·向量数据库
寒秋丶24 分钟前
Milvus:Schema详解(四)
数据库·人工智能·python·ai·ai编程·milvus·向量数据库
曾经的三心草28 分钟前
springcloud二-Seata3- Seata各事务模式
后端·spring·spring cloud
梨轻巧29 分钟前
pyside6常用控件:QComboBox() 下拉菜单
python
王中阳Go32 分钟前
又整理了一场真实Golang面试复盘!全是高频坑+加分话术,面试遇到直接抄
后端·面试·go