gpt4 book ai didi

python - 使用 Python 使用 Tumblr API 时无法获取 OAuth "Request Token"

转载 作者:太空狗 更新时间:2023-10-30 01:17:10 26 4
gpt4 key购买 nike

到目前为止,我一直在使用库来处理 OAuth,但最近我一直在深入挖掘,试图了解底层的 OAuth 流程。目前,我正在尝试连接到 Tumblr API v2通过以下简单代码使用 OAuth 1.0a:

import urllib, urllib2, time, random, hmac, base64, hashlib

def makenonce():
random_number = ''.join( str( random.randint( 0, 9 ) ) for _ in range( 40 ) )
m = hashlib.md5( str( time.time() ) + str( random_number ) )
return m.hexdigest()

def encodeparams(s):
return urllib.quote( str( s ), safe='~' )

# Actual key and secret from a test app created using a dummy Tumblr account
consumer_key = '97oAujQhSaQNv4XDXzCjdZlOxwNyhobmDwmueJBCHWsFFsW7Ly'
consumer_secret = '5q1dpF659SOgSUb0Eo52aAyoud8N8QOuJu6enCG92aDR6WoMlf'

#oauth URLs
request_tokenURL = 'http://www.tumblr.com/oauth/request_token'

#oauth params
oauth_parameters = {
'oauth_consumer_key' : consumer_key,
'oauth_nonce' : makenonce(),
'oauth_timestamp' : str(int(time.time())),
'oauth_signature_method' : "HMAC-SHA1",
'oauth_version' : "1.0"
}

normalized_parameters = encodeparams( '&'.join( ['%s=%s' % ( encodeparams( str( k ) ), encodeparams( str( oauth_parameters[k] ) ) ) for k in sorted( oauth_parameters )] ) )
# Since I'm focusing only on getting the request token for now, I set this to POST.
normalized_http_method = 'POST'
normalized_http_url = encodeparams( request_tokenURL )
signature_base_string = '&'.join( [normalized_http_method, normalized_http_url, normalized_parameters] )
oauth_key = consumer_secret + '&'
hashed = hmac.new( oauth_key, signature_base_string, hashlib.sha1 )
oauth_parameters['oauth_signature'] = base64.b64encode( hashed.digest() )
oauth_header = 'Authorization: OAuth realm="http://www.tumblr.com",' + 'oauth_nonce="' + oauth_parameters['oauth_nonce'] + '",' + 'oauth_timestamp="' + oauth_parameters['oauth_timestamp'] + '",' + 'oauth_consumer_key="' + oauth_parameters['oauth_consumer_key'] + '",' + 'oauth_signature_method="HMAC-SHA1",oauth_version="1.0",oauth_signature="' + oauth_parameters['oauth_signature'] +'"'

# sample oauth_header generated by the code above:
# Authorization: OAuth realm="http://www.tumblr.com",oauth_nonce="c200a0e06f30b84b851ac3e99a71054b",oauth_timestamp="1315231855",oauth_consumer_key="97oAujQhSaQNv4XDXzCjdZlOxwNyhobmDwmueJBCHWsFFsW7Ly",oauth_signature_method="HMAC-SHA1",oauth_version="1.0",oauth_signature="kVAlmwolCX0WJIvTF9MB2UV5rnU="


req = urllib2.Request( request_tokenURL )
req.add_header( 'Authorization', oauth_header )
# If all goes well, Tumblr should send me the oauth request token.
print urllib2.urlopen( req ).read()

Tumblr 返回的不是 OAuth 请求 token ,而是 HTTP 错误 401:未经授权

我尝试过但没有成功的事情:

  1. oauth_version 从“1.0”更改为“1.0a”,然后再改回来。
  2. OAuth 指南要求在 consumer_secret 末尾添加“&”以获取 oauth_key。我稍后尝试删除“&”,看看是否有任何不同。
  3. 检查 OAuth 参数是否已排序,确实如此。
  4. 没有将字符串“Authorization:”添加到 oauth_header,稍后又将其添加回来。两者都没有任何区别。

我哪里做错了?

最佳答案

在上面的代码中只做了两个简单的修改就解决了这个问题:

  1. normalized_http_method = 'GET' #not POST
  2. oauth_header = 'OAuth realm="http://www...' # “Authorization”这个词是不必要的。我之前已经按照列表把它去掉了在“我尝试过但没有成功的事情”中,但是 (1) 中列出的错误使我偏离了轨道。随着 (1) 的解决,我可以看出“授权”确实是不必要的。

当我终于弄对了时,Tumblr 发给我的 OAuth 请求 token :oauth_token=mbRUgyDkPePfkEztiLELMqUl1kyNXEcaTCCwpb7SoXDF9mhiTF&oauth_token_secret=5pXllXGKA8orAaUat1G7ckIfMfYup8juMBAgEELUkeMZoC3pv6&oauth_callback_confirmed=true

这是一次性 token ,为了完整起见,我将其列在此处。

关于python - 使用 Python 使用 Tumblr API 时无法获取 OAuth "Request Token",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7309478/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com