我目前正在使用requests-oauthlib库进行oauth 1签名请求。
from requests_oauthlib import OAuth1Session
self.session = OAuth1Session(
OAUTH_CONSUMER_KEY, OAUTH_CONSUMER_SECRET,
oauth_token, oauth_token_secret,
signature_type='auth_header', realm='http://api.twitter.com'
)
self.session.headers = self.default_headers
self.session.verify = self.verify
self.session.proxies.update(self.proxies)使用它,我可以成功地发出oauth 1请求。但是我需要http 2,我想使用异步文件。这就是为什么我试图切换到httpx和authlib。
from authlib.integrations.httpx_client import OAuth1Client
self.session = OAuth1Client(
OAUTH_CONSUMER_KEY, OAUTH_CONSUMER_SECRET,
oauth_token, oauth_token_secret,
http2=True,
headers=self.default_headers,
proxies=self.proxies,
verify=self.context
)
self.session.auth.realm = 'http://api.twitter.com'使用requests-oauthlib,我可以在没有问题的情况下发出签名请求。但是,当我试图对httpx做同样的操作时,我得到了这样的响应:
{
"errors": [{
"code": 32,
"message": "Could not authenticate you."
}]
}如果我使用web调试器查看一下,我可以验证身份验证头获得了所有正确的密钥,但是在使用httpx时请求失败了。有人对如何解决这个问题或如何正确地调试这个问题有任何建议吗?(预先谢谢:)
发布于 2022-11-07 11:20:23
我正在开发类似的解决方案,在使用httpx时,您应该导入AsyncOAuth1Client而不是OAuth1Client。
https://stackoverflow.com/questions/72697836
复制相似问题