web-dev-qa-db-ja.com

Pythonを使用してoauth2 access_tokenを取得するにはどうすればよいですか?

プロジェクトのために、Postmanでテスト目的で使用したこのデータを誰かがくれました:

Postmanでは、これは完全に機能します。

認証URL: https://api.example.com/oauth/access_token
アクセストークンのURL: https://api.example.com/access_token
クライアントID:abcde
クライアントシークレット:12345
トークン名:access_token
付与タイプ:クライアント資格情報

私が必要なのは、アクセストークンを取り戻すことだけです。

一度、続行できるアクセストークンを取得しました。

私はすでにいくつかのPythonパッケージといくつかのカスタムコードを試しましたが、どうやらこの一見単純なタスクが本当の頭痛の種を作り始めます。

私が試した1つの例:

import httplib
import base64
import urllib
import json

def getAuthToken():
    CLIENT_ID = "abcde"
    CLIENT_SECRET = "12345"
    TOKEN_URL = "https://api.example.com/oauth/access_token"

    conn = httplib.HTTPSConnection("api.example.com")

    url = "/oauth/access_token"

    params = {
        "grant_type": "client_credentials"
    }

    client = CLIENT_ID
    client_secret = CLIENT_SECRET

    authString = base64.encodestring('%s:%s' % (client, client_secret)).replace('\n', '')

    requestUrl = url + "?" + urllib.urlencode(params)

    headersMap = {
        "Content-Type": "application/x-www-form-urlencoded",
        "Authorization": "Basic " + authString
    }

    conn.request("POST", requestUrl, headers=headersMap)

    response = conn.getresponse()

    if response.status == 200:
        data = response.read()
        result = json.loads(data)

        return result["access_token"]

それから私はこれを持っています:

import requests
import requests.auth

CLIENT_ID = "abcde"
CLIENT_SECRET = "12345"
TOKEN_URL = "https://api.example.com/oauth/access_token"
REDIRECT_URI = "https://www.getpostman.com/oauth2/callback"

def get_token(code):
    client_auth = requests.auth.HTTPBasicAuth(CLIENT_ID, CLIENT_SECRET)
    post_data = {"grant_type": "client_credentials",
                 "code": code,
                 "redirect_uri": REDIRECT_URI}
    response = requests.post(TOKEN_URL,
                             auth=client_auth,
                             data=post_data)
    token_json = response.json()
    return token_json["access_token"]

これが機能する場合、codeパラメータに何を入れればよいですか

誰かが私をここで助けてくれることを本当に願っています。

前もって感謝します。

10
Johan Vergeer

やっとできた

これは私が使用したコードです:

class ExampleOAuth2Client:
    def __init__(self, client_id, client_secret):
        self.access_token = None

        self.service = OAuth2Service(
            name="foo",
            client_id=client_id,
            client_secret=client_secret,
            access_token_url="http://api.example.com/oauth/access_token",
            authorize_url="http://api.example.com/oauth/access_token",
            base_url="http://api.example.com/",
        )

        self.get_access_token()

    def get_access_token(self):
        data = {'code': 'bar',
                'grant_type': 'client_credentials',
                'redirect_uri': 'http://example.com/'}

        session = self.service.get_auth_session(data=data, decoder=json.loads)

        self.access_token = session.access_token
11
Johan Vergeer

単に(Facebook認証の場合):

import requests, json

access_token = requests.get("https://graph.facebook.com/oauth/access_token?grant_type=client_credentials&client_id=your_client_id&client_secret=your_client_secret").json()["access_token"]

または、 rauthライブラリ を使用できます。

docs には、facebook oAuth2認証の興味深い例があります。

from rauth import OAuth2Service

facebook = OAuth2Service(
client_id='your_client_id',
client_secret='your_client_secret',
name='facebook',
authorize_url='https://graph.facebook.com/oauth/authorize',
access_token_url='https://graph.facebook.com/oauth/access_token',
base_url='https://graph.facebook.com/')

そしてセッションを開いた後:

session = facebook.get_auth_session(data={'code': 'foo','redirect_uri': redirect_uri})

セッションjsonにはあなたのアクセストークンがあります

2
CarloV