使用oauth令牌通过imap连接到Gmail时,身份验证失败

哈里森

我正在编写一个使用Google身份验证登录名的脚本。我目前正在获取访问令牌和用户的电子邮件地址,并将其传递给使用imap连接到gmail的函数,然后对电子邮件进行一些处理。我生成了身份验证字符串,就像我见过别人做网上但是我收到此错误:

Traceback (most recent call last):
  File "/Library/Python/2.7/site-packages/flask/app.py", line 2000, in __call__
    return self.wsgi_app(environ, start_response)
  File "/Library/Python/2.7/site-packages/flask/app.py", line 1991, in wsgi_app
    response = self.make_response(self.handle_exception(e))
  File "/Library/Python/2.7/site-packages/flask/app.py", line 1567, in handle_exception
    reraise(exc_type, exc_value, tb)
  File "/Library/Python/2.7/site-packages/flask/app.py", line 1988, in wsgi_app
    response = self.full_dispatch_request()
  File "/Library/Python/2.7/site-packages/flask/app.py", line 1641, in full_dispatch_request
    rv = self.handle_user_exception(e)
  File "/Library/Python/2.7/site-packages/flask/app.py", line 1544, in handle_user_exception
    reraise(exc_type, exc_value, tb)
  File "/Library/Python/2.7/site-packages/flask/app.py", line 1639, in full_dispatch_request
    rv = self.dispatch_request()
  File "/Library/Python/2.7/site-packages/flask/app.py", line 1625, in dispatch_request
    return self.view_functions[rule.endpoint](**req.view_args)
  File "/Users/Harrison/Desktop/Uber/UberStats.py", line 60, in index
    return Uber_Cost(email_address, access_token)
  File "/Users/Harrison/Desktop/Uber/UberStats.py", line 103, in Uber_Cost
    mail.authenticate('XOAUTH2', lambda x: auth_string)
  File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/imaplib.py", line 364, in authenticate
    raise self.error(dat[-1])
error: [AUTHENTICATIONFAILED] Invalid credentials (Failure)

我打印出的访问代码,以及我与我登录的电子邮件地址,所以我知道那些值不为空。我生成的身份验证字符串错误吗?我是否无法正确使用imap进行身份验证?

这是我的代码:

from flask import Flask, request, url_for, session, redirect, jsonify
from flask_oauth import OAuth
import json
import imaplib
import email
from bs4 import BeautifulSoup
import base64





GOOGLE_CLIENT_ID = '****'
GOOGLE_CLIENT_SECRET = '***'
REDIRECT_URI = '/authorized'  # one of the Redirect URIs from Google APIs console

SECRET_KEY = 'Uber'
DEBUG = True

app = Flask(__name__)
app.secret_key = 'Uber'
oauth = OAuth()

google = oauth.remote_app('google',
                          base_url='https://www.google.com/accounts/',
                          authorize_url='https://accounts.google.com/o/oauth2/auth',
                          request_token_url=None,
                          request_token_params={'scope': 'https://www.googleapis.com/auth/userinfo.email',
                                                'response_type': 'code'},
                          access_token_url='https://accounts.google.com/o/oauth2/token',
                          access_token_method='POST',
                          access_token_params={'grant_type': 'authorization_code'},
                          consumer_key=GOOGLE_CLIENT_ID,
                          consumer_secret=GOOGLE_CLIENT_SECRET)


@app.route('/')
def index():
    access_token = session.get('access_token')
    if access_token is None:
        return redirect(url_for('login'))

    access_token = access_token[0]
    from urllib2 import Request, urlopen, URLError

    headers = {'Authorization': 'OAuth '+access_token}
    req = Request('https://www.googleapis.com/oauth2/v1/userinfo',
                  None, headers)
    try:
        res = urlopen(req)
    except URLError, e:
        if e.code == 401:
            # Unauthorized - bad token
            session.pop('access_token', None)
            return redirect(url_for('login'))
        return res.read()
    j = json.loads(res.read())
    email_address = j['email']
    print email_address, access_token
    return Uber_Cost(email_address, access_token)


@app.route('/login')
def login():
    callback=url_for('authorized', _external=True)
    return google.authorize(callback=callback)



@app.route(REDIRECT_URI)
@google.authorized_handler
def authorized(resp):
    access_token = resp['access_token']
    session['access_token'] = access_token, ''
    return redirect(url_for('index'))


@google.tokengetter
def get_access_token():
    return session.get('access_token')


def GenerateOAuth2String(username, access_token, base64_encode=True):
    auth_string = 'user=%s\1auth=Bearer %s\1\1' % (username, access_token)
    if base64_encode:
        auth_string = base64.b64encode(auth_string)
    return auth_string




def Uber_Cost(email_address, access_token):


    auth_string = GenerateOAuth2String(email_address, access_token, base64_encode=False)



    mail = imaplib.IMAP4_SSL('imap.gmail.com')
    mail.debug = 4
    mail.authenticate('XOAUTH2', lambda x: auth_string)
    mail.select('INBOX')
最高

它看起来就像你根据你最新的代码获得了身份验证()方法了。

您还需要https://mail.google.com/OAuth范围来与IMAP和SMTP服务器进行身份验证。

这就是它添加到你的范围要求,并确保您的应用配置为在谷歌应用程序控制台此范围:

request_token_params={'scope': 'https://www.googleapis.com/auth/userinfo.email https://mail.google.com/',
                                            'response_type': 'code'},

Google OAUTH2协议和范围记录在其开发人员页面上

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

通过身份验证连接到MongoDB失败

通过Spring Boot连接到Tibco主题时身份验证失败

连接到MongoDB时身份验证始终失败

使用身份验证连接到站点时,Swift 3 NSURLSession/NSURLConnection HTTP 加载失败

使用令牌通过令牌进行身份验证,如果令牌失败,则通过会话进行身份验证?

JavaMail连接到Office 365 XOAUTH2以进行IMAP身份验证失败

部落Gmail OAuth2身份验证失败

为什么我不能使用JavaMail(IMAP协议)连接到我的邮箱,并收到“没有身份验证失败”错误消息?

OAuth:通过身份验证后,通过路由使用访问令牌

使用 nestjs 身份验证时身份验证失败

连接到MongoDB服务集群时出错:SASL身份验证步骤上服务器返回错误:身份验证错误身份验证失败

致命:连接到 PosgreSQL 时,用户“postgres”的 SSPI 身份验证失败

尝试连接到Clickhouse数据库时,Sqlalchemy显示“代码516身份验证失败”

使用令牌身份验证时如何在Django通道中的Websocket连接中对用户进行身份验证

如何使用ADAL / OAuth向CRM Online进行身份验证并通过令牌请求数据?

如何使用Twisted通过OAuth2.0身份验证检查Gmail

尝试通过Windows身份验证连接到MySQL时出现NullReferenceException

spring boot oauth2-使用基本身份验证时无法获取访问令牌

在Linux上通过附加身份验证连接到Wifi

通过连接字符串访问Azure Blob存储时身份验证失败

使用身份验证令牌的Axios请求有时在Safari中失败

Office 365 REST日历API,用于使用OAuth承载令牌进行身份验证时创建失败的HTTP-403事件

mailkit imap身份验证失败

是否可以通过Java EE webapp使用Windows身份验证连接到SQL Server?

如何使用Windows身份验证通过sqlalchemy连接到SQL Server?

无法通过 mysql CLI 工具使用 IAM 身份验证连接到 RDS 实例

无法使用公钥身份验证通过 SSH 连接到 Windows

使用EF Core通过AAD身份验证连接到Azure SQL服务器

如何使用knex模块从Node.JS通过Windows身份验证连接到SQL Server