Django发送邮件

【图书介绍】《Django 5企业级Web应用开发实战(视频教学版)》_django 5企业级web应用开发实战(视频教学版)-CSDN博客

Django 5框架Web应用开发_夏天又到了的博客-CSDN博客

本文学习怎么使用Django发送邮件。

尽管使用Python的smtplib模块发送电子邮件相对容易,但Django还是在其上提供了两个轻巧的包装程序。提供这些包装程序的目的是使电子邮件发送速度更快,使开发过程中的电子邮件发送测试更加容易,并为不能使用SMTP的平台提供支持。

Django框架发送邮件的代码位于django.core.mail模块中,最简单的方法就是通过调用send_mail()方法来实现。

send_mail()方法的语法格式如下:

复制代码
send_mail(

    subject,

    message,

    from_email,

    recipient_list,

    fail_silently=False,

    auth_user=None,

    auth_password=None,

    connection=None,

    html_message=None)

其中的subject、message、from_email和recipient_list参数是必需的。

  • subject参数:字符串。
  • message参数:字符串。
  • from_email参数:字符串。
  • recipient_list参数:邮件地址的字符串列表。
  • fail_silently参数:布尔值。如果参数设为False,则send_mail()方法将会触发一个smtplib.SMTPException异常。
  • auth_user参数:用于验证SMTP服务器的可选用户名。如果未提供此选项,则Django框架将使用EMAIL_HOST_USER设置的值。
  • auth_password参数:用于验证SMTP服务器的可选用户名密码。如果未提供此选项,则Django框架将使用EMAIL_HOST_PASSWORD设置的值。
  • connection参数:用于发送邮件的可选电子邮件后端。如果未指定,将使用默认后端的实例。
  • html_message参数:如果提供了html_message参数,则生成的电子邮件将是多部分/替代电子邮件,其消息为"text/plain"类型,而html_message为"text/html"内容类型。
  • 返回值:该函数的返回值将是成功传递的消息数(可以为0或1,因为只能发送一条消息)。

请看下面关于发送邮件的代码实例。

【代码11-11】

复制代码
01  from django.core.mail import send_mail

02 

03  send_mail(

04      'Subject here',

05      'Here is the message.',

06      'from@example.com',

07      ['to@example.com'],

08      fail_silently=False,

09  )

使用EMAIL_HOST和EMAIL_PORT设置中指定的SMTP主机和端口发送邮件。EMAIL_HOST_USER和EMAIL_HOST_PASSWORD设置(如果已设置)用于对SMTP服务器进行身份验证,而EMAIL_USE_TLS和EMAIL_USE_SSL设置控制是否使用安全连接。

相关推荐
曹牧5 小时前
Oracle:前缀匹配之REGEXP_LIKE
数据库·oracle
暴躁小师兄数据学院8 小时前
【AI大数据工程师特训笔记】第05讲:关联查询
数据库·sql·oracle
倔强的石头_8 小时前
《Kingbase护城河》——跨平台环境下的数据库联调实战
数据库
lzhdim8 小时前
SQL 入门 17:MySQL 数据类型:从字符串到 JSON 的全面解析
数据库·sql·mysql·json
杨云龙UP8 小时前
Oracle RAC / ODA 生产环境指定 PDB 启动 SOP
linux·运维·数据库·oracle
kingwebo'sZone8 小时前
在Cent上安装Mysql 8.0的遇到的问题和解决办法
数据库·mysql·adb
幽络源小助理9 小时前
最新知识付费系统网站源码 PC+H5双端 附安装教程 – 幽络源源码网
大数据·数据库
小白考证进阶中9 小时前
Oracle OCP证书报考&考试全指南
数据库·oracle·oracle ocp·ocp认证·oracle认证·甲骨文认证·oracle ocp题库
Leon-Ning Liu10 小时前
【真实经验分享】 ORA-600 [qesmaGetTblSeg1]
数据库·oracle
与数据交流的路上10 小时前
MySQL 优化 -- 相关
数据库·mysql