简体   繁体   English

在Google App Engine中使用smtp和Gmail发送电子邮件时发生身份验证错误

[英]Auth error sending email with smtp and Gmail in Google App Engine

I'm trying to send an email with my Google Apps email via SMTP in App Engine, but I get an 'Authorization required' during the sendmail call. 我正在尝试通过App Engine中的SMTP与Google Apps电子邮件一起发送电子邮件,但在sendmail呼叫期间收到“需要授权”。 It seems the auth call itself succeeds. 似乎auth调用本身成功。

Here's the message I'm trying to send. 这是我要发送的消息。 It's a draft retrieved via IMAP, so I know the access token is good. 这是通过IMAP检索的草稿,因此我知道访问令牌很好。 It's generated by Python's email.Message.as_string method. 它是由Python的email.Message.as_string方法生成的。

MIME-Version: 1.0
Received: by 10.76.124.8 with HTTP; Thu, 3 Apr 2014 00:12:26 -0700 (PDT)
To: Ela Honoridez II <ela@mydomain.com>
Date: Thu, 3 Apr 2014 15:12:26 +0800
Message-ID: <CAN8SGD-joz9Adq9QpKowME3N0xmgwegYGYwRVQh_9kbGfTa75A@mail.gmail.com>
Subject: =?UTF-8?B?RGVsYXllZCBlbWFpbCB0ZXN0ICMyIMOlw5/iiJo=?=
From: John Del Rosario <john@mydomain.com>
Content-Type: multipart/alternative; boundary=14dae94edfeda1125304f61e1fec

--14dae94edfeda1125304f61e1fec
Content-Type: text/plain; charset=UTF-8

foo bar

--14dae94edfeda1125304f61e1fec
Content-Type: text/html; charset=UTF-8

<div dir="ltr">foo bar</div>

--14dae94edfeda1125304f61e1fec--

Here's my code: 这是我的代码:

auth_string = 'user=%s^Aauth=Bearer %s^A^A' % ('john@mydomain.com', access_token)
smtp = smtplib.SMTP('smtp.gmail.com', 587)
smtp.set_debuglevel(True)
smtp.ehlo()
smtp.starttls()
smtp.ehlo()
smtp.docmd('AUTH', 'XOAUTH2 ' + base64.b64encode(auth_string))
smtp.sendmail('john@mydomain.com', ['ela@mydomain.com'], rfc822_msg_str)

And here's the debug messages from smtp. 这是来自smtp的调试消息。

send: 'ehlo dev.myapp.appspot.com\r\n'
reply: '250-mx.google.com at your service, [74.125.182.85]\r\n'
reply: '250-SIZE 35882577\r\n'
reply: '250-8BITMIME\r\n'
reply: '250-STARTTLS\r\n'
reply: '250-ENHANCEDSTATUSCODES\r\n'
reply: '250 CHUNKING\r\n'
reply: retcode (250); Msg: mx.google.com at your service, [74.125.182.85]
SIZE 35882577
8BITMIME
STARTTLS
ENHANCEDSTATUSCODES
CHUNKING
send: 'STARTTLS\r\n'
reply: '220 2.0.0 Ready to start TLS\r\n'
reply: retcode (220); Msg: 2.0.0 Ready to start TLS
send: 'ehlo dev.myapp.appspot.com\r\n'
reply: '250-mx.google.com at your service, [74.125.182.85]\r\n'
reply: '250-SIZE 35882577\r\n'
reply: '250-8BITMIME\r\n'
reply: '250-AUTH LOGIN PLAIN XOAUTH XOAUTH2 PLAIN-CLIENTTOKEN\r\n'
reply: '250-ENHANCEDSTATUSCODES\r\n'
reply: '250 CHUNKING\r\n'
reply: retcode (250); Msg: mx.google.com at your service, [74.125.182.85]
SIZE 35882577
8BITMIME
AUTH LOGIN PLAIN XOAUTH XOAUTH2 PLAIN-CLIENTTOKEN
ENHANCEDSTATUSCODES
CHUNKING
send: 'AUTH XOAUTH2 (snipped base64 encoded auth string)\r\n'
reply: '501 5.5.2 Cannot Decode response s9sm12053561igw.16 - gsmtp\r\n'
reply: retcode (501); Msg: 5.5.2 Cannot Decode response s9sm12053561igw.16 - gsmtp
send: u'mail FROM:<john@mydomain.com> size=651\r\n'
reply: '530-5.5.1 Authentication Required. Learn more at\r\n'
SMTPSenderRefused: (530, '5.5.1 Authentication Required. Learn more at\n5.5.1 http://support.google.com/mail/bin/answer.py?answer=14257 s9sm12053561igw.16 - gsmtp', u'john@mydomain.com')

You from email should be registered with Google App Engine app. 您的电子邮件地址应已在Google App Engine应用程序中注册。 Google put restriction for from email ids. Google对电子邮件ID设置了限制。 Here is working code. 这是工作代码。

__author__ = 'Om Narayan'
__revision__ = '$'
__version__ = '0.1'
__maintainer__ = 'Om Narayan'
__email__ = 'om.narayan29@gmail.com'
__status__ = 'Prototype'

import json
from app.baseRequestHandler import *
from google.appengine.api import mail
from webapp2_extras import auth, sessions, jinja2


class Email(BaseRequestHandler):
  def send(self, values, templateFile):
    message = mail.EmailMessage(sender="<Sender Name> <sender email id registered with google app engine>",
                            subject=values['subject'])
    message.to = "%s <%s>" % (values['userName'], values['userEmail'])
    message.body = self.jinja2.render_template('/email/%s.txt' % templateFile, **values)
    message.html = self.jinja2.render_template('/email/%s.html' % templateFile, **values)
    message.send()

  def sendMulti(self, values, templateFile):
    message = mail.EmailMessage(
                sender="%s (<Sender Name>)  <sender email id registered with google app engine>" % values["authorName"],
                subject=values['subject'])
    message.to = "%s" % (values['recipients'])
    message.body = self.jinja2.render_template('/email/%s.txt' % templateFile, **values)
    message.html = self.jinja2.render_template('/email/%s.html' % templateFile, **values)
    message.send()

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM