ошибка при получении токена от oauth2.googleapis.com с помощью gmail API - PullRequest
0 голосов
/ 20 июня 2019

Я пытался создать простую программу, которая отправляет электронную почту с помощью API gmails (так что, надеюсь, мне не нужно включать «менее безопасные приложения»).однако, я начал получать ошибку во время тестирования.

Traceback (most recent call last):
  File "C:\Users\<me>\Desktop\Python code\Email\email - 1.1\gmailAPI.py", line 51, in <module>
    main()
  File "C:\Users\<me>\Desktop\Python code\Email\email - 1.1\gmailAPI.py", line 32, in main
    creds = flow.run_local_server()
  File "C:\Python3.7\lib\site-packages\google_auth_oauthlib\flow.py", line 442, in run_local_server
    self.fetch_token(authorization_response=authorization_response)
  File "C:\Python3.7\lib\site-packages\google_auth_oauthlib\flow.py", line 263, in fetch_token
    self.client_config['token_uri'], **kwargs)
  File "C:\Python3.7\lib\site-packages\requests_oauthlib\oauth2_session.py", line 284, in fetch_token
    verify=verify, proxies=proxies)
  File "C:\Python3.7\lib\site-packages\requests\sessions.py", line 581, in post
    return self.request('POST', url, data=data, json=json, **kwargs)
  File "C:\Python3.7\lib\site-packages\requests_oauthlib\oauth2_session.py", line 425, in request
    headers=headers, data=data, **kwargs)
  File "C:\Python3.7\lib\site-packages\requests\sessions.py", line 533, in request
    resp = self.send(prep, **send_kwargs)
  File "C:\Python3.7\lib\site-packages\requests\sessions.py", line 646, in send
    r = adapter.send(request, **kwargs)
  File "C:\Python3.7\lib\site-packages\requests\adapters.py", line 510, in send
    raise ProxyError(e, request=request)
requests.exceptions.ProxyError: HTTPSConnectionPool(host='oauth2.googleapis.com', port=443): Max retries exceeded with url: /token (Caused by ProxyError('Cannot connect to proxy.', OSError('Tunnel connection failed: 403 Forbidden')))

Я почти уверен, что это связано с отправкой слишком большого количества запросов в моем тестировании.Тем не менее, мне нужно отойти, чтобы преодолеть это, чтобы я мог продолжить выяснять, как я могу использовать и манипулировать API.

это то, что я использую для тестирования API Gmail.По сути, это просто Python Quckstart.

from __future__ import print_function
import pickle
import os.path
from googleapiclient.discovery import build
from google_auth_oauthlib.flow import InstalledAppFlow
from google.auth.transport.requests import Request
from time import sleep

# If modifying these scopes, delete the file token.pickle.
SCOPES = ['https://www.googleapis.com/auth/gmail.readonly']

def main():
    """Shows basic usage of the Gmail API.
    Lists the user's Gmail labels.
    """
    creds = None
    # The file token.pickle stores the user's access and refresh tokens, and is
    # created automatically when the authorization flow completes for the first
    # time.
    if os.path.exists('token.pickle'):
        with open('token.pickle', 'rb') as token:
            creds = pickle.load(token)
    # If there are no (valid) credentials available, let the user log in.
    if not creds or not creds.valid:
        if creds and creds.expired and creds.refresh_token:
            creds.refresh(Request())
        else:
            flow = InstalledAppFlow.from_client_secrets_file(
                "client_secret.json", SCOPES)
            sleep(1)
            creds = flow.run_local_server()
        # Save the credentials for the next run
        with open('token.pickle', 'wb') as token:
            pickle.dump(creds, token)

    service = build('gmail', 'v1', credentials=creds)

    # Call the Gmail API
    results = service.users().labels().list(userId='me').execute()
    labels = results.get('labels', [])

    if not labels:
        print('No labels found.')
    else:
        print('Labels:')
        for label in labels:
            print(label['name'])

if __name__ == '__main__':
    main()

1 Ответ

0 голосов
/ 21 июня 2019

Я думаю, что у вас такая же ошибка из этого ТАКОГО сообщения . Пожалуйста, проверьте ваш формат, используя message.get.

message = service.users().messages().get(userId=user_id, id=msg_id,
                                         format='raw').execute()

print 'Message snippet: %s' % message['snippet']

msg_str = base64.urlsafe_b64decode(message['raw'].encode('ASCII'))

mime_msg = email.message_from_string(msg_str)
...