Twitter API 1.1提供错误代码32

时间:2012-12-30 22:22:24

标签: php oauth twitter-oauth

因此。我正在尝试从列表Feed中获取所有状态。更具体地说,这一个https://dev.twitter.com/docs/api/1.1/get/lists/statuses

据我所知,它正在使用OAuth 1.0a。 我的问题是,我得到一个错误代码32。

我正在使用以下代码:

<?php function buildBaseString($baseURI, $method, $params) { 
    $r = array(); 
    ksort($params); 
    foreach($params as $key=>$value){
        $r[] = "$key=" . rawurlencode($value);
    } 
    return $method."&" . rawurlencode($baseURI) . '&' . rawurlencode(implode('&', $r)); 
}

function buildAuthorizationHeader($oauth) {
    $r = 'Authorization: OAuth ';
    $values = array(); 
    foreach($oauth as $key=>$value) 
        $values[] = "$key=\"" . rawurlencode($value) . "\"";
    $r .= implode(', ', $values); 
    return $r; 
}

$url = "https://api.twitter.com/1.1/lists/statuses.json?slug=danskere-i-udlandet&owner_screen_name=d_fodbold&count=20";
$oauth_access_token = "29194047-Dzwsoo1KiQg69dbabt3nS2ezjjNzlbZdlKpLWsOOG"; 
$oauth_access_token_secret = "secret"; 
$consumer_key = "iCV8UbKjmq9LAw1XIvTQ"; 
$consumer_secret = "secret";
$oauth = array( 'oauth_consumer_key' => $consumer_key,
                'oauth_nonce' => md5(microtime()), 
                'oauth_signature_method' => 'HMAC-SHA1', 
                'oauth_token' => $oauth_access_token, 
                'oauth_timestamp' => time(), 
                'oauth_version' => '1.0');

$base_info = buildBaseString($url, 'GET', $oauth); 

$composite_key = rawurlencode($consumer_secret) . '&' . rawurlencode($oauth_access_token_secret); 
$oauth_signature = base64_encode(hash_hmac('sha1', $base_info, $composite_key, true)); 
$oauth['oauth_signature'] = $oauth_signature;

// Make Requests 
$header = array(buildAuthorizationHeader($oauth)); 
$options = array(   CURLOPT_HTTPHEADER => $header, 
                //CURLOPT_POSTFIELDS => $postfields, 
                    CURLOPT_HEADER => false, 
                    CURLOPT_URL => $url, 
                    CURLOPT_RETURNTRANSFER => true, 
                    CURLOPT_SSL_VERIFYPEER => false);


$feed = curl_init(); 
curl_setopt_array($feed, $options); 
$json = curl_exec($feed); 
curl_close($feed);


$twitter_data = json_decode($json);
var_dump($twitter_data);
exit();?>

我无法弄清楚那里有什么问题。

我希望你们中的一些人可以。

2 个答案:

答案 0 :(得分:2)

我发现了。基线的制作方式不对。

查询字符串必须包含在其中,并按字母顺序排序。

答案 1 :(得分:0)

我认为您的oauth_nonce存在问题。我不认为md5(microtime())是一个好的nonce生成器。尝试像Twitter开发者文档中提到的那样关于authorizing requests

  

oauth_nonce参数是应用程序应该使用的唯一标记   为每个唯一请求生成。 Twitter将使用此值   确定是否已多次提交请求。该   此请求的值由base64编码32个字节生成   随机数据,并剥离所有非单词字符,但任何   应该产生相对随机的字母数字字符串的方法   好在这里。