• django发送邮件send_mail&send_mass_mail


    一、配置

    在setting.py中进行相关配置:

    EMAIL_HOST = 'smtp.sina.cn'                 #SMTP地址
    EMAIL_PORT = 25                             #SMTP端口
    EMAIL_HOST_USER = 'xxxxxxxxxxx@sina.cn'     #我自己的邮箱
    EMAIL_HOST_PASSWORD = 'xxxxxxxxxxxx'        #我的邮箱密码
    EMAIL_USE_TLS = False                       #与SMTP服务器通信时,是否启动TLS链接(安全链接)。默认是false
    EMAIL_FROM = 'xxxxxxxxxxx@sina.cn'          #发件人        

    二、发送邮件

    新建一个send_email.py文件。采用diango中的send_email()方法进行邮件的发送。

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

    发送邮件最简单的方法是使用django.core.mail.send_mail()。

    subject、message、from_email和 recipient_list 参数是必须的。

    • subject:一个字符串,为邮件标题。
    • message:一个字符串,邮件正文。
    • from_email:一个字符串,发件人。
    • recipient_list:一个由邮箱地址组成的字符串列表。recipient_list 中的每一个成员都会在邮件信息的“To:”区域看到其它成员。
    • fail_silently: 是否报错,True的话表忽略异常。
    • connection: 表示这个的链接对象。
    from django.core.mail import send_mail
    from MxOnline2.settings import EMAIL_FROM
    
    email_title = '慕学在线网注册激活平台'
    email_body = '请点击下面的链接激活你的账号:xxx'
    send_status = send_mail(email_title, email_body, EMAIL_FROM, [xxxxx.qq.com])

    一次性发送多个邮件:

    send_mass_mail(datatuple, fail_silently=False, auth_user=None,auth_password=None, connection=None)
    from django.core.mail import send_mass_mail
    
    message1 = ('Subject here', 'Here is the message', 'from@example.com', ['first@example.com', 'other@example.com'])
    message2 = ('Another Subject', 'Here is another message', 'from@example.com', ['second@test.com'])
    
    send_mass_mail((message1, message2), fail_silently=False)

    备注:send_mail 每次发邮件都会建立一个连接,发多封邮件时建立多个连接。而 send_mass_mail 是建立单个连接发送多封邮件,所以一次性发送多封邮件时 send_mass_mail 要优于 send_mail。

    高级功能

    前面2个函数其实是对EmailMessage这个类进行封装,使他们使用起来,相当的简单,但它们的功能是十分有限的,例如,无法抄送(cc)或者私密发送(bcc)以及无法加入附件(attachments)

    如果要是用刚刚说的功能,就必须直接使用EmailMessage这个类。

    # 类定义
    class EmailMessage(object):
     def __init__(self, subject='', body='', from_email=None, to=None, bcc=None,
         connection=None, attachments=None, headers=None, cc=None,
         reply_to=None):
     pass
    # 使用
    from django.core.mail import EmailMessage
    email = EmailMessage(
     'Hello',
     'Body goes here',
     'from@example.com',
     ['to1@example.com', 'to2@example.com'],
     ['bcc@example.com'],
     reply_to=['another@example.com'],
     headers={'Message-ID': 'foo'},
    )

    这个类参数中,抄送cc,私密发送bcc,回复reply_to都是一个列表。

    值得一提的是attachments,它也是一个列表,它的元素始:MIMEBase对象或者(filename, content, mimetype)这个元组,即包括显示的文件名,文件数据,文件类型。

    它还提供一些方法,主要提2个:send()发送邮件,以及attach()添加附件

    直接使用Backend

    如果我们像上面那样直接去调用EmailMessage.send() ,这样一次连接connection就只会发送一个message,那么如果我想发送多个message呢?

    这个时候我们就有必要去了解backend了

    其实django sending_email功能是由backend的控制的,这个类提供几个方法:

    open() : 开个一个连接

    close() : 关闭这个连接

    send_messages(email_messages) : 接受一个EmailMessage对象的列表,然后将多个信息发送出去,而EmailMessage的send()方法就是调用这个方法,只是传递的参数是[self],就只有一个对象。

    那么,其实如果我们能控制connection的开关,那么我们就能实现多个EmailMessage对象在email发送出去,这个时候,我们考虑通过上下文自动控制打开与关闭操作的方式:

    from django.core import mail
    with mail.get_connection() as connection:
     mail.EmailMessage(
      subject1, body1, from1, [to1],
      connection=connection,
     ).send()
     mail.EmailMessage(
      subject2, body2, from2, [to2],
      connection=connection,
     ).send()

    这样的方法显得有点笨拙,我们肯定希望能够使用send_messages() ,直接传递一个EmailMessage对象的列表给它。我们注意到上面的代码get_connection()函数,其实它就是能够直接去获取到一个backend的对象,然后通过直接调用这个send_messages()方法。

    from django.core import mail
    connection = mail.get_connection()
    # get_EmailMessage_list返回一个EmailMessage对象的列表
    messages = get_EmailMessage_list()
    connection.send_messages(messages)

    这个直接调用send_messages(messages) ,如果此时没有open链接的话,它会先打开连接,执行关自动关闭。

    这样子好像还有点不灵活,那也可以亲自控制open与close!

    from django.core import mail
    connection = mail.get_connection()
    connection.open()
    email1 = mail.EmailMessage(
     'Hello',
     'Body goes here',
     'from@example.com',
     ['to1@example.com'],
     connection=connection,
    )
    email1.send()
    email2 = mail.EmailMessage(
     'Hello',
     'Body goes here',
     'from@example.com',
     ['to2@example.com'],
    )
    email3 = mail.EmailMessage(
     'Hello',
     'Body goes here',
     'from@example.com',
     ['to3@example.com'],
    )
    connection.send_messages([email2, email3])
    connection.close()

    这个例子使用EmailMessage.send()connection.send_messages()的使用,这个只是展示作用,并没用必要同时使用

    backend类型与定制

    说了那么多的backend,那它到底是什么,其实默认的它就是:backends.smtp.EmailBackend

    # 在django.core.mail。backends.smtp.下
    class EmailBackend(BaseEmailBackend):
     def __init__(self, host=None, port=None, username=None, password=None,
         use_tls=None, fail_silently=False, use_ssl=None, timeout=None,
         ssl_keyfile=None, ssl_certfile=None,**kwargs):
      pass

    就是这个类,它继承BaseEmailBackend了,是默认的backend,控制了整个send mail的过程,当然django还提供了其他backend,不过作用不是很大。

    Console backend: 将邮件直接写到你的stdout中。

    Dummy backend: 没有实际作用。

    你只需要在setting中指定你的backend:

    EMAIL_BACKEND = 'django.core.mail.backends.dummy.EmailBackend'

     

    转自https://blog.csdn.net/geerniya/article/details/78562003、https://www.jb51.net/article/134480.htm

  • 相关阅读:
    为什么大多数IOC容器使用ApplicationContext,而不用BeanFactory
    重温Java泛型,带你更深入地理解它,更好的使用它!
    看完了这篇,面试的时候人人都能单手撸冒泡排序!
    JAVA基础4---序列化和反序列化深入整理(Hessian序列化)
    VS Code 变身小霸王游戏机!
    equals()方法和hashCode()方法详解
    openFeign远程调用时使用Mybatis-plus的IPage接口进行返回分页数据失败的记录
    通过express快速搭建一个node服务
    UML 类图
    jdk命令行工具系列——检视阅读
  • 原文地址:https://www.cnblogs.com/youleng/p/9372210.html
Copyright © 2020-2023  润新知