13.flask-mail

安装

pip install Flask-Mail

配置 Flask-Mail

Flask-Mail 使用标准的 Flask 配置 API 进行配置。下面这些是可用的配置型(每一个将会在文档中进行解释):

  • MAIL_SERVER : 默认为 ‘localhost’

  • MAIL_PORT : 默认为 25

  • MAIL_USE_TLS : 默认为 False

  • MAIL_USE_SSL : 默认为 False

  • MAIL_DEBUG : 默认为 app.debug

  • MAIL_USERNAME : 默认为 None

  • MAIL_PASSWORD : 默认为 None

  • MAIL_DEFAULT_SENDER : 默认为 None

  • MAIL_MAX_EMAILS : 默认为 None

  • MAIL_SUPPRESS_SEND : 默认为 app.testing

  • MAIL_ASCII_ATTACHMENTS : 默认为 False

如果获取授权码,如下:

image-20200905161854150

相关配置放到配置文件中,通过如下,进行获取配置:

初始化实例

邮件是通过一个 Mail 实例进行管理:

在这个例子中所有的邮件将会使用传入到 Mail 实例中的应用程序的配置项进行发送。

发送邮件

为了能够发送邮件,首先需要创建一个 Message 实例:

  • sender:发送者邮箱

  • recipients:接收者的邮箱

设置一个或者多个收件人:

如果设置了 MAIL_DEFAULT_SENDER,就不必再次填写发件人,默认情况下将会使用配置项的发件人:

config.py

app.py

如果 sender 是一个二元组,它将会被分成姓名和邮件地址:

邮件内容可以包含主体以及/或者 HTML:

最后,发送邮件的时候请使用 Flask 应用设置的 Mail 实例:

大量邮件

通常在一个 Web 应用中每一个请求会同时发送一封或者两封邮件。在某些特定的场景下,有可能会发送数十或者数百封邮件,不过这种发送工作会给交离线任务或者脚本执行。

  • subject:邮件主题

与电子邮件服务器的连接会一直保持活动状态直到所有的邮件都已经发送完成后才会关闭(断开)。

有些邮件服务器会限制一次连接中的发送邮件的上限。你可以设置重连前的发送邮件的最大数,通过配置 MAIL_MAX_EMAILS

附件

如果 MAIL_ASCII_ATTACHMENTS 设置成 True 的话,文件名将会转换成 ASCII 的。 当文件名是以 UTF-8 编码的时候,使用邮件转发的时候会修改邮件内容并且混淆 Content-Disposition 描述,这个时候 MAIL_ASCII_ATTACHMENTS 配置项是十分有用的。转换成 ASCII 的基本方式就是对 non-ASCII 字符的去除。任何一个 unicode 字符能够被 NFKD 分解成一个或者多个 ASCII 字符。

简单测试

app.py

image-20200905163801447
image-20200905163839279

最后更新于

这有帮助吗?