django发送邮件

目录

1、首先在浏览器打开qq邮箱进行登录,登录。链接:https://mail.qq.com/

2、进入到设置。注:登录之后会出现下面两种界面的其中一种

 3、进入设置后

4、配置setting.py文件

5、在views.py视图文件导入发送邮件的类

  6 编写视图函数


这篇文章以QQ邮箱发送邮件为例。

1、首先在浏览器打开qq邮箱进行登录,登录。链接:https://mail.qq.com/

2、进入到设置。注:登录之后会出现下面两种界面的其中一种

第一张的设置已标出

第二张的设置在下图的位置

 3、进入设置后

        如果是第一张图开启POP3/SMTP服务

        

根据提示,短信验证成功后会出现密钥,讲密钥复制粘贴保存很重要!!!

如果是第二张图找到第三方服务

        把IMAP/SMTP服务开启生成授权码

 根据提示,验证成功后会出现授权码,讲授权码复制粘贴保存很重要!!!

4、配置setting.py文件

    
EMAIL_BACKEND = 'django.core.mail.backend.smtp.EmailBackend'
EMAIL_HOST = 'smtp.qq.com'#发送邮箱的地址,因为我用的是qq邮箱所以是qq邮箱的服务器地址
EMAIL_PORT = 25 #端口号
EMAIL_HOST_USER = ''#发送消息邮箱即开通服务的邮箱
EMAIL_HOST_PASSWORD = ''#密钥或授权码
EMAIL_FORM = ''#来路邮箱和EMAIL_HOST_USER同一个

5、在views.py视图文件导入发送邮件的类

form django.core.mail import send_mail

send_mail(subject,message,from_email,recipient_list,fail_silently=False,auth_user=None,auth_password=None)

参数:subject、message、 from_email、recipient_list为必须的

(1)、subject:邮箱的主题

(2)、message:发送的内容

(3)、from_email:发送邮件的名称

(4)、recipient_list:是个列表,每一项都是一个邮箱地址,是邮件的收件地址

(5)、fail_silently: 一个布尔值。若为 False send_mail() 会在发生错误时抛出 smtplib.SMTPException 。可在 smtplib
             文档找到一系列可能的异常,它们都是 SMTPException 的子类。
(6)、 auth_user: 可选的用户名,用于验证登陆 SMTP 服务器。 若未提供, Django 会使用 EMAIL_HOST_USER 指定
              的值。
(7)、  auth_password: 可 选 的 密 码 , 用 于 验 证 登 陆 SMTP 服 务 器 。 若 未 提 供 , Django 会 使 用
               EMAIL_HOST_PASSWORD 指定的值。
(8)、connection: 可选参数,发送邮件使用的后端。若未指定,则使用默认的后端。
(9)、html_message: 若提供了 html_message ,会使邮件成为 multipart/alternative 的实例, message 的内容类型则是
        text/plain ,并且 html_message 的内容类型是 text/html
(10)、返回值会是成功发送的信息的数量(只能是 0 1 ,因为同时只能发送一条消息)

  6 编写视图函数

import re
from django.shortcuts import HttpResponse
from django.core.mail import send_mail
def gerCode(request):
    email = request.GET.get('email')#get传参,接收收件邮箱
    if not re.match(r"^\w+[-_.]*[a-zA-Z0-9]+@[a-zA-Z0-9]+\.[a-zA-Z]{2,3}$",emali):
        #判断邮箱格式是否符合,不符合停止
        return HttpResponse('邮箱不符合格式')
    isturn = send_email('这是验证码','这是我发送的消息',[email],fail_silently=False)
    if isturn:
        return HttpResponse('发送成功')
    else:
        return HttpResponse('发送失败')
    

注:记得配置路由

### 在 Django 中实现发送邮件验证码的功能 要在 Django 项目中实现发送邮件验证码的功能,可以按照以下方法设计模型、视图以及配置电子邮件服务。 #### 数据库模型定义 为了存储生成的验证码及其相关信息,可以在 `models.py` 文件中定义一个名为 `Vaild_Code` 的数据表: ```python from django.db import models class Vaild_Code(models.Model): code_content = models.CharField(max_length=8, verbose_name="验证码") # 存储验证码内容 code_time = models.DateTimeField(auto_now=True, verbose_name="创建时间") # 自动生成当前时间 code_status = models.IntegerField(default=0, verbose_name="状态", help_text="1 表示已使用;0 表示未使用") # 定义验证码的状态 code_user = models.EmailField(verbose_name="邮箱") # 关联用户的邮箱地址 def __str__(self): return f"{self.code_user} - {self.code_content}" ``` 此部分的设计基于已有引用中的字段说明[^3]。 --- #### 配置邮件服务 在 Django 项目的 `settings.py` 文件中,需要设置用于发送邮件的相关参数。这些参数通常包括 SMTP 服务器地址、端口、用户名和密码等信息。 以下是典型的邮件配置代码片段: ```python EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend' EMAIL_HOST = 'smtp.example.com' # 替换为实际使用的SMTP服务器域名 EMAIL_PORT = 587 # 常见的SMTP端口号 EMAIL_USE_TLS = True # 是否启用TLS加密传输 EMAIL_HOST_USER = 'your_email@example.com' # 发件人的邮箱账号 EMAIL_HOST_PASSWORD = 'password' # 对应发件人邮箱的授权码或密码 DEFAULT_FROM_EMAIL = EMAIL_HOST_USER # 默认发件人显示名称 ``` 上述配置来源于关于 Django 设置邮件功能的内容描述[^2]。 --- #### 创建并发送验证码逻辑 接下来,在视图函数中完成验证码的生成与发送操作。可以通过 Python 的内置模块 `random` 来随机生成指定长度的字符串作为验证码,并通过 Django 提供的 `send_mail()` 方法将其发送至目标邮箱。 下面是一段完整的视图处理流程: ```python import random from django.core.mail import send_mail from .models import Vaild_Code from django.conf import settings def generate_code(): """生成6位数的随机验证码""" chars = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz' length = len(chars) result = ''.join(random.choice(chars) for _ in range(6)) return result def send_verification_code(request): email = request.POST.get('email') # 获取前端提交的目标邮箱地址 if not email: return {"status": "error", "message": "请输入有效的电子邮箱"} try: is_registered = UserProfile.objects.filter(email=email).exists() # 判断该邮箱是否已经注册过账户[^4] if not is_registered: return {"status": "error", "message": "该邮箱尚未注册"} verification_code = generate_code() valid_record = Vaild_Code(code_content=verification_code, code_user=email) # 将新生成的验证码保存到数据库 valid_record.save() subject = "您的验证码" message = f"您好,您正在尝试登录/找回密码,请输入以下验证码:{verification_code}\n有效期为5分钟。" from_email = settings.DEFAULT_FROM_EMAIL recipient_list = [email] send_result = send_mail(subject, message, from_email, recipient_list) if send_result > 0: return {"status": "success", "message": "验证码已成功发送,请查收邮件"} else: return {"status": "error", "message": "验证码发送失败,请稍后再试"} except Exception as e: return {"status": "error", "message": str(e)} ``` 以上代码实现了从接收请求到生成验证码再到最终发送的过程[^1]。 --- #### 验证验证码的有效性 当用户收到邮件后返回填写验证码时,需验证其有效性。这一步骤同样应在视图层实现,具体做法是从数据库查询对应记录并与用户提供值对比。 示例代码如下所示: ```python from datetime import timedelta, timezone from django.utils.timezone import now def verify_code(request): input_code = request.POST.get('code') user_email = request.POST.get('email') current_time = now() five_minutes_ago = current_time - timedelta(minutes=5) record = Vaild_Code.objects.filter( code_user=user_email, code_content=input_code, code_status=0, code_time__gte=five_minutes_ago ).first() if record: record.code_status = 1 # 更新状态为已使用 record.save(update_fields=['code_status']) return {"status": "success", "message": "验证码校验通过"} else: return {"status": "error", "message": "验证码错误或者已失效"} ``` 这里的时间范围判断依据是确保验证码仅限于最近五分钟内有效。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值