0

我正在尝试使用 lyft 开发者 API。我创建了一个新应用程序来获取客户端 ID 和客户端密码。我正在按照https://developer.lyft.com/docs/authentication中的步骤在我的 python 代码中获取访问令牌。但我总是得到错误,“未经授权的客户”。谁能指出我的错误?

def __init__(self):
    self.client_id = 'MY_ID'
    self.client_secret = 'MY_SECRET'

    # obtain access token
    self.token = self.__generate_token__()

    # define variables to be used in the request parameters
    token_val = 'Bearer '+self.token
    self.headers = {'Authorization':token_val}

def __generate_token__(self):
    url = 'https://api.lyft.com/oauth/token'

    # define request parameters
    payload = {"Content-Type": "application/json",
               "grant_type": "client_credentials",
               "scope": "public"}
    # request data
    res = requests.post(url,
                        data = payload,
                        auth = (self.client_id, self.client_secret))
    # extract the token from the response
    token = res.json()['access_token']
    return token
4

1 回答 1

0

这是 Java 客户端的工作示例

https://github.com/yschimke/oksocial/blob/175bdbf66e312d8bdf79183a140c2c5270329cf2/src/main/java/com/baulsupp/oksocial/services/lyft/LyftClientAuthFlow.java

看起来错误的主要事情是在 POST 数据正文中发送“Content-Type”,而不是作为指示数据格式的标头。

请求 api看来,您应该发送“json = payload”而不是“data”。但我不是这个 python API 的专家。

上述java代码的curl等价物也适用

$ ./oksocial --curl --authorize lyft --client
Authorising Lyft API
Lyft Client Id [***********]:
Lyft Client Secret [********************************]:
curl -X POST -H "Authorization:Basic ******************" -H "Connection:Keep-Alive" -H "User-Agent:okhttp/3.5.0" -H "Host:api.lyft.com" -H "Accept-Encoding:gzip" -H "Content-Length:55" -H "Content-Type:application/json; charset=utf-8" -H "Content-Type:application/json; charset=utf-8" -d '{"grant_type": "client_credentials", "scope": "public"}' https://api.lyft.com/oauth/token
于 2016-12-26T07:45:47.487 回答