Errno 90 Сообщение слишком длинное при отправке электронной почты

Я пытаюсь отправить электронное письмо с вложением, используя python, и это не удается из-за ошибки followibng:

2016-06-03 17:10:09,527 - sbo_cloud.documents.views - send_mail|10324 - ERROR - Traceback (most recent call last):
      File "/home/project/django/sbo_cloud/documents/views.py", line 10285, in send_mail
        send_email(user, company, to_addr, subject, message, from_mail=from_addr, cc=cc_addr, bcc=bcc_addr, is_attachment=is_attachment, files_to_attach=pdf_file_dict, notify_sender=notify_sender)
      File "/home/project/django/sbo_cloud/core/utils.py", line 1989, in send_email
        server.sendmail(msg['From'], to_addrs, msg.as_string())
      File "/usr/lib/python2.7/smtplib.py", line 736, in sendmail
        (code, resp) = self.data(msg)
      File "/usr/lib/python2.7/smtplib.py", line 503, in data
        self.send(q)
      File "/usr/lib/python2.7/smtplib.py", line 320, in send
        print>>stderr, 'send:', repr(str)
    IOError: [Errno 90] Message too long

Любая идея, почему это происходит и почему это происходит не на всех серверах, это происходит на двух из них, но не на третьем, используя одни и те же данные? Серверы работают под управлением Ubuntu 14. Связан ли этот питон или сервер и как его можно избежать?

Редакция:

Вот мой код для отправки электронного письма:

def send_email(user, company, to_mail, subject, message, is_attachment=False, files_to_attach={}, **kwargs):
# def send_email(company, to_mail, subject, message, **kwargs):
    """
    sends an email, kwargs can be from_mail, cc and bcc lists, subject, message_text and message_html
    This method is used for the company sending an email, not for the program
    is_attachment will be true when file should be attached.
    files_to_attach is a dictionaty whose key is filename and object corresponding to key is fileobject
    that needs to be attached.
    """
    config = EmailConfig(user=user, company=company)

    # from_mail = kwargs.get('from_mail', config.from_address)
    from_mail = config.username

    # Header class is smart enough to try US-ASCII, then the charset we
    # provide, then fall back to UTF-8.
    header_charset = 'ISO-8859-1'

    # We must choose the body charset manually
    for body_charset in 'US-ASCII', 'ISO-8859-1', 'UTF-8':
        try:
            message.encode(body_charset)
        except UnicodeError:
            pass
        else:
            break

    # Split real name (which is optional) and email address parts
    sender_name, sender_addr = parseaddr(from_mail)
    recipient_name, recipient_addr = parseaddr(to_mail)

    # We must always pass Unicode strings to Header, otherwise it will
    # use RFC 2047 encoding even on plain ASCII strings.
    from_alias_addr, from_addr = parseaddr(kwargs.get('from_mail', ''))
    sender_name = str(Header(unicode(from_alias_addr), header_charset))
    recipient_name = str(Header(unicode(recipient_name), header_charset))

    # Make sure email addresses do not contain non-ASCII characters
    sender_addr = sender_addr.encode('ascii')
    recipient_addr = recipient_addr.encode('ascii')

    msg = MIMEMultipart('alternative')
    # Create the body of the message (a plain-text and an HTML version).
    # html = kwargs.get('message_html', message)
    # Record the MIME types of both parts - text/plain and text/html.
    # Create the message ('plain' stands for Content-Type: text/plain)
    part1 = MIMEText(message.encode(body_charset), 'plain', body_charset)
    html_message = "<br />".join(message.split("\n"))
    part2 = MIMEText(html_message.encode(body_charset), 'html', body_charset)
    # Attach parts into message container.
    # According to RFC 2046, the last part of a multipart message, in this case
    # the HTML message, is best and preferred.
    msg.attach(part1)
    msg.attach(part2)
    try:
        if is_attachment == True:
            tmpmsg = msg
            msg = MIMEMultipart()
            msg.attach(tmpmsg)
            for file_name, file_to_attach in files_to_attach.iteritems() :
                file_format, enc = guess_type(file_name)
                main, sub = file_format.split('/')
                part3 = MIMEBase(main, sub)
# #                part3 = MIMEBase('application', "octet-stream")
                part3.set_payload(file_to_attach.read())
                Encoders.encode_base64(part3)
                part3.add_header('Content-Disposition', 'attachment; filename="%s"' % file_name)
                msg.attach(part3)
    except Exception as e:
        print e

    from_username = formataddr((from_alias_addr, from_addr))
    if email_re.search(from_username):
        msg['From'] = from_username
    else:  # adresa email introdusa invalida, se foloseste cea de la configurare
        msg['From'] = formataddr((sender_name, sender_addr))

    msg['To'] = formataddr((recipient_name, recipient_addr))
    msg['Subject'] = Header(unicode(subject), header_charset)
    msg['X-Priority'] = '1'
    msg['X-MSMail-Priority'] = 'High'
    msg['Importance'] = 'High'
    msg['Date'] = formatdate(localtime=True)

    if kwargs.get('notify_sender', False):
        msg['Disposition-Notification-To'] = formataddr((sender_name, sender_addr))
        msg['Return-Receipt-To'] = formataddr((sender_name, sender_addr))

    # Create message container - the correct MIME type is multipart/alternative.
    # cc (and bcc) must be a string of emails (can contain user name) sepparated by coma "addr1@webbi.ro, addr2@webbi.ro"
    cc = kwargs.get('cc', config.cc)
    bcc = kwargs.get('bcc', config.bcc)
    cc_addrs, bcc_addrs = [], []
    if cc:
        for addr in cc.split(','):
            cc_name, cc_addr = parseaddr(addr)
            cc_name = str(Header(unicode(cc_name), header_charset))
            cc_addr = cc_addr.encode('ascii')
            cc_addrs.append(formataddr((cc_name, cc_addr)))
    if bcc:
        for addr in bcc.split(','):
            bcc_name, bcc_addr = parseaddr(addr)
            bcc_name = str(Header(unicode(bcc_name), header_charset))
            bcc_addr = bcc_addr.encode('ascii')
            bcc_addrs.append(formataddr((bcc_name, bcc_addr)))

    return_path = kwargs.get('return_path', None)
    if return_path:
        msg['reply-to'] = return_path

    if cc != "":
        msg['Cc'] = cc
    if bcc != "":
        msg['Bcc'] = bcc
    to_addrs = [msg['To']] + cc_addrs + bcc_addrs

    return_path = kwargs.get('return_path', None)
    if return_path:
        msg['reply-to'] = return_path

    if not config.ssl:
        try:
            with_ssl = False
            server = smtplib.SMTP(config.server_address, int(config.port), timeout=45)  # timeout=45
        except SMTPServerDisconnected:
            with_ssl = True
            server = smtplib.SMTP_SSL(config.server_address, int(config.port), timeout=45)  # timeout=45
            config.ssl = True
    else:
        try:
            with_ssl = True
            server = smtplib.SMTP_SSL(config.server_address, int(config.port), timeout=45)  # timeout=45
        except SMTPServerDisconnected:
            with_ssl = False
            server = smtplib.SMTP(config.server_address, int(config.port), timeout=45)  # timeout=45
            config.ssl = False
    server.set_debuglevel(settings.DEBUG)
    encryptor = SBAESCrypt()
    password = encryptor.decrypt(config.password)
    if not with_ssl and config.tls:
        server.starttls()
    server.login(config.username, password)
    # sendmail function takes 3 arguments: sender's address, recipient's address
    # and message to send - here it is sent as one string.
    server.sendmail(msg['From'], to_addrs, msg.as_string())
    server.quit()

    config.save()

Спасибо

0 ответов

Другие вопросы по тегам