Python 无法使用access\u令牌从Twitter检索经过身份验证的数据
我正在尝试用python创建泛型类,它将完成所有oAuth过程,然后允许从任何oAuth支持服务(例如Twitter、LinkedIn)检索数据 编辑: 我有客户密钥和密码以及访问令牌密钥和密码,当我尝试请求任何资源请求时,我会出现以下错误:Python 无法使用access\u令牌从Twitter检索经过身份验证的数据,python,oauth,twitter-oauth,Python,Oauth,Twitter Oauth,我正在尝试用python创建泛型类,它将完成所有oAuth过程,然后允许从任何oAuth支持服务(例如Twitter、LinkedIn)检索数据 编辑: 我有客户密钥和密码以及访问令牌密钥和密码,当我尝试请求任何资源请求时,我会出现以下错误: {“error”:“无法通过OAuth进行身份验证。”,“request”:“\/1\/statuses\/retweeted\u by\u me.json}” 知道为什么吗 我的代码是: import httplib import time import
{“error”:“无法通过OAuth进行身份验证。”,“request”:“\/1\/statuses\/retweeted\u by\u me.json
}”
知道为什么吗
我的代码是:
import httplib
import time
import oauth as oauth
# settings for the local test consumer
SERVER = 'api.twitter.com'
RESOURCE_URL = 'https://api.twitter.com/1/statuses/retweeted_by_me.json'
CONSUMER_KEY = 'MY_CUSTOMER_KEY'
CONSUMER_SECRET = 'MY_CUSTOMER_SECRET'
ACCESS_TOKEN_KEY = 'MY_ACCESS_TOKEN_KEY'
ACCESS_TOKEN_SECRET = 'MY_ACCESS_TOKEN_SECRET'
# example client using httplib with headers
class SimpleOAuthClient(oauth.OAuthClient):
def __init__(self, server):
self.server = server
self.connection = httplib.HTTPSConnection(self.server)
def access_resource(self, oauth_request):
# via post body
# -> some protected resources
self.connection.request(oauth_request.http_method, RESOURCE_URL)
response = self.connection.getresponse()
return response.read()
def run_example2():
print '** OAuth Python Library Example **'
client = SimpleOAuthClient(SERVER, )
consumer = oauth.OAuthConsumer(CONSUMER_KEY, CONSUMER_SECRET)
signature_method_hmac_sha1 = oauth.OAuthSignatureMethod_HMAC_SHA1()
pause()
# access some protected resources
print '* Access protected resources ...'
pause()
token = oauth.OAuthToken('ACCESS_TOKEN_KEY', 'ACCESS_TOKEN_SECRET')
oauth_request = oauth.OAuthRequest.from_consumer_and_token(consumer, token=token, http_method='GET', http_url=RESOURCE_URL)
oauth_request.sign_request(signature_method_hmac_sha1, consumer, token)
print 'REQUEST (via post body)'
print 'parameters: %s' % str(oauth_request.parameters)
pause()
params = client.access_resource(oauth_request)
print 'GOT'
print 'non-oauth parameters: %s' % params
pause()
def pause():
print ''
time.sleep(1)
if __name__ == '__main__':
run_example2()
print 'Done.'
授权https://api.twitter.com/oauth/authenticate"
这是用于OAuth的不正确的URL。如果查看Twitter,它们会声明“使用GET-OAuth/authorize端点而不是/OAuth/authenticate”。将URL更改为”https://api.twitter.com/oauth/authorize“然后再试一次。我通过更改self.connection.request(oauth\u request.http\u方法,资源\u URL)成功地修复了它。” to
self.connection.request(oauth\u request.http\u方法,oauth\u request.to\u url())
请注意,只有当oauth_request.http_方法为GET时,它才有效。不,它不起作用。此外,我编辑了问题并简化了代码