使用 OAuth 2.0 和 Python 请求检索 Yahoo API 的访问令牌

Retrieve access token for Yahoo API using OAuth 2.0 and Python requests

我正在尝试检索 Yahoo API 的访问令牌,使用本文档中描述的显式授权流程: https://developer.yahoo.com/oauth2/guide/flows_authcode

一切正常,直到 步骤 4:交换访问令牌的授权码

我编写了以下 python 脚本来检索代码:

import urllib2
import requests
import json



url = 'https://api.login.yahoo.com/oauth2/get_token'
body = "grant_type=authorization_code&redirect_uri=oob&code=************"
headers = {
'Authorization': 'Basic **************', 
'Content-Type': 'application/json'
}

r = requests.post(url, data=body, headers=headers)
print r

注意:我用“****”替换了敏感数据

现在,当我执行脚本时,我只收到“401”错误消息。

我 100% 确定登录凭据没问题,所以这似乎与我发出请求的方式有关。这也是我第一次在 python 中使用 "requests"。

如果您能给我一些关于代码的反馈,并且我正确传递了 header 和 body 信息,那就太好了。我特别不确定 body 的通过。该文档仅说明以下内容:

Sample Request Body: grant_type=authorization_code&redirect_uri=https%3A%2F%2Fwww.example.com&code=abcdef

将您的 body 变量更改为字典,即

body = {
    'grant_type': 'authorization_code',
    'redirect_uri': 'oob',
    'code': '************',
}

无需进行其他更改。希望对你有帮助。

棘手的问题已经解决了。但可能其他用户仍然会遇到相同的 401 错误,即使他们像我一样使用正确的字典。问题是 link 中第 2 步生成的代码只能使用一次。这将得到相同的 401 错误。这花了我一些时间来弄清楚。希望这对其他人有帮助。