如何使用python httplib2与Mailgun发送电子邮件附件

时间:2017-02-17 11:06:57

标签: python google-app-engine google-drive-api mailgun httplib2

我正在使用带有Mailgun API的httplib2来发送我使用Google云端硬盘下载的电子邮件附件,电子邮件正在发送但没有附件..以下是我的代码..

DRIVE = discovery.build('drive', 'v3', http=http_auth)

        request = DRIVE.files().export_media(fileId=file_id, mimeType='application/pdf')

        fh = io.BytesIO()
        downloader = MediaIoBaseDownload(fh, request)

        done = False
        while done is False:
            status, done = downloader.next_chunk()
            logging.info("Download %d%%." % int(status.progress() * 100))

        messages = {
            "from": sender,
            "to": recipient,
            "subject": 'Attachment Mail from Mailgun',
            "text": 'Testing',
            "attachment": fh.getvalue()
        }

         url = URL

        data = {
            "from": messages['from'],
            "to": messages['to'],
            "subject": messages['subject'],
            "text": messages['text'],
            "attachment": messages['attachment']
        }

        pl = urllib.urlencode(data)

        http = httplib2.Http()
        http.add_credentials('api', API)

        resp, content = http.request(
            url, 'POST', pl,
            headers={"Content-Type": "application/x-www-form-urlencoded"})

3 个答案:

答案 0 :(得分:1)

我们使用mailgun API使用Appengine发送电子邮件并阅读cloud storage,同样的原则将适用于google drive

我建议的第一件事是研究StringIO。它允许您以比BytesIO更简单的方式模拟使用appengine沙箱中的文件,但两者都产生支持file objects的python调用.read(),因此这应该适用于两者。

将文件作为file like object后,您只需将其正确传递给API即可。以下示例使用requests库,因为它使文件POST很容易,并且与appengine兼容。

请注意,在这种情况下open(FILE_PATH_1, 'rb')file like object,您只需将其替换为您的文件对象:

def send_complex_message():
    return requests.post("https://api.mailgun.net/v2/DOMAIN/messages",
          auth=("api", "key-SECRET"),
          files={
              "attachment[0]": ("FileName1.ext", open(FILE_PATH_1, 'rb')),
              "attachment[1]": ("FileName2.ext", open(FILE_PATH_2, 'rb'))
          },
          data={"from": "FROM_EMAIL",
                "to": [TO_EMAIL],
                "subject": SUBJECT,
                "html": HTML_CONTENT
          })

答案 1 :(得分:0)

def send_mailgun(收件人,主题,html,文件,文件名,cc,密件抄送):

MAILGUN_URL ='https://api.mailgun.net/v3/DOMAIN/messages'MAILGUN_KEY ='密钥秘密'

data = {“” subject“:subject,” from“:” FROM_EMAIL“,” to“:to,” html“:html}

如果cc!=“”:data [“ cc”] = cc

如果密件抄送!=“ =”:data [“ bcc”] =密件抄送

如果file_name和file_name!=“”:resp = requests.post(MAILGUN_URL,auth =(“ api”,MAILGUN_KEY),files = [(“ attachment”,(file_name,file))],data = data)否则:resp = requests.post(MAILGUN_URL,auth =(“ api”,MAILGUN_KEY),data = data)

答案 2 :(得分:0)

这很晚了……我很久以前解决了..下面是我所做的:

import io
import base64
from google.appengine.api import urlfetch
from libs.poster.encode import multipart_encode, MultipartParam

from oauth2client.appengine import AppAssertionCredentials
from googleapiclient.http import MediaIoBaseDownload
from apiclient.discovery import build
from httplib2 import Http

request = drive.files().export_media(fileId=spreadsheet_id, mimeType='application/pdf')

        fh = io.BytesIO()
        downloader = MediaIoBaseDownload(fh, request)

        done = False
        while done is False:
            status, done = downloader.next_chunk()

        message = {
            'from': 'noreply',
            'to': 'recipient',
            'subject': mail_subject,
            'text': text,
            'filename': filename,
            'attachment': fh.getvalue()
        }

        # send email using mailgun
        resp = send_attachment_email(message)


# Compose an email with an attachment
def send_attachment_email(messages):

url = 'mailgun_api_url'
api = 'api-key'

load = {
    "from": messages['from'],
    "to": messages['to'],
    "subject": messages['subject'],
    "text": messages['text'],
    "attachment": MultipartParam(
        "attachment",
        filename=messages['filename'],
        filetype='application/pdf',
        value=messages['attachment'])
}

payload, hd = multipart_encode(load)

hd['Authorization'] = 'Basic %s' % (base64.b64encode(api),)

resp = urlfetch.fetch(url=url, payload="".join(payload), method='POST',
                      headers=hd, validate_certificate=True)
logging.info(resp.status_code)
logging.info(resp.content)

return resp.status_code