我正在使用带有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"})
答案 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