2010-02-11 31 views
4

我正在Python中编写一个OAuth脚本。OAuth与Python中的Twitter脚本不起作用

为了测试这个,我使用Twitter API。但它运作不好。

def test(): 
    params = { 
      "oauth_consumer_key": TWITTER_OAUTH_CONSUMER_KEY, 
      "oauth_nonce": "".join(random.choice(string.digits + string.letters) for i in xrange(7)), 
      "oauth_signature_method": "HMAC-SHA1", 
      "oauth_timestamp": str(int(time.time())), 
      "oauth_token": res_dict["oauth_token"], 
      "oauth_version": "1.0", 
      } 
    status = {"status": u"Always_look_on_the_bright_side_of_life".encode("UTF-8")} 
    print status 
    params.update(status) 
    url = "http://twitter.com/statuses/update.xml" 
    key = "&".join([TWITTER_OAUTH_CONSUMER_SECRET, res_dict["oauth_token_secret"]]) 
    msg = "&".join(["POST", urllib.quote(url,""), 
        urllib.quote("&".join([k+"="+params[k] for k in sorted(params)]), "-._~")]) 
    print msg 
    signature = hmac.new(key, msg, hashlib.sha1).digest().encode("base64").strip() 
    params["oauth_signature"] = signature 
    req = urllib2.Request(url, 
      headers={"Authorization":"OAuth", "Content-type":"application/x-www-form-urlencoded"}) 
    req.add_data("&".join([k+"="+urllib.quote(params[k], "-._~") for k in params])) 
    print req.get_data() 
    res = urllib2.urlopen(req).read() 
    print res 

该脚本(status =“Always_look_on_the_bright_side_of_life”)正在工作。

但是,如果状态为“总是看到生命的光明一面”(用空格替换下划线),它不起作用(正在返回HTTP错误401:未经授权)。

我引用this question,但失败。

请给我一些建议。谢谢。

+0

+1在Python示例中使用适当的示例字符串。 – 2010-02-11 13:18:03

回答

0

解决此问题的最简单方法是在status = {"status": u"Always_look_on_the_bright_side_of_life".encode("UTF-8")}之后添加status = urllib.quote(status)。这将根据需要转义空格和其他特殊字符。

1

前段时间我在FaceBook中遇到了与FaceBook相同的问题。问题是服务器端的签名验证失败。请参阅您的签名代代码:

msg = "&".join(["POST", urllib.quote(url,""), 
       urllib.quote("&".join([k+"="+params[k] for k in sorted(params)]), "-._~")]) 
print msg 
signature = hmac.new(key, msg, hashlib.sha1).digest().encode("base64").strip() 

它使用字符串的原始(非编码)形式生成签名。然而,在服务器端生成验证对URL引用字符串签名:

req.add_data("&".join([k+"="+urllib.quote(params[k], "-._~") for k in params])) 

修复代码,你需要做的创建从URL编码参数签名解决这一行:

msg = "&".join(["POST", urllib.quote(url,""), 
       urllib.quote("&".join([k+"="+urllib.quote(params[k], "-._~") for k in sorted(params)]), "-._~")])