簡體   English   中英

Twitter API-無法驗證oauth簽名和令牌PHP / CURL

[英]Twitter API - Failed to validate oauth signature and token PHP / CURL

在過去的幾個小時中,我嘗試了所有類型的變體,但根據Twitter API,這應該從步驟1開始就可以了!

我對以下腳本所做的1個添加是:$ header = array(“ Expect:”);

我發現此問題有助於解決關於stackoverflow的另一個問題,即獲得被拒絕的問題/ 100-繼續。

問題:每次都無法驗證oauth簽名和令牌!!!

我的帖子數據示例:

Array ( [oauth_callback] => http://www.mysite.com//index.php [oauth_consumer_key] => hidden [oauth_nonce] => hidden [oauth_signature_method] => HMAC-SHA1 [oauth_timestamp] => 1301270847 [oauth_version] => 1.0 )

和我的頭數據:

Array ( [0] => Expect: )

腳本:

$consumer_key = "hidden";
$consumer_secret = "hidden";
function Post_Data($url,$data,$header){
    $ch = curl_init();  
    curl_setopt($ch, CURLOPT_URL, $url); 
    curl_setopt($ch, CURLOPT_POST, 1);  
    curl_setopt($ch, CURLOPT_POSTFIELDS,$data);
    curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
    $result = curl_exec($ch);  
    curl_close($ch);
    return $result;
    }
$data['oauth_callback'] = "http://".$_SERVER['HTTP_HOST'].$_SERVER['PHP_SELF'];
$data['oauth_consumer_key'] = $consumer_key;
$data['oauth_nonce'] = md5(time());
$data['oauth_signature_method'] = "HMAC-SHA1";
$data['oauth_timestamp'] = time();
$data['oauth_version'] = "1.0";
$header = array("Expect:");
$content = Post_Data("http://api.twitter.com/oauth/request_token",$data,$header);
print_r($content);

有人能看到我可能在這里犯的一個明顯錯誤嗎? 最好不要與其他人一起使用代碼,因為大多數示例都具有完整的類和大量的函數,我正在尋找最簡單的方法!

您的問題是您的請求中沒有包含OAuth簽名。
您可以在此頁面上閱讀有關概念的信息。
這里可以找到有效的實現。

我遇到了同樣的問題,我所缺少的是將header傳遞給curl請求。 如該問題所示,我還發送了$ header = array('Expect:'),這是我的問題。 我開始在標頭中與其他數據一起發送簽名,如下所示,它為我解決了這種情況。

$header = calculateHeader($parameters, 'https://api.twitter.com/oauth/request_token');

function calculateHeader(array $parameters, $url)
    {
        // redefine
        $url = (string) $url;

        // divide into parts
        $parts = parse_url($url);

        // init var
        $chunks = array();

        // process queries
        foreach($parameters as $key => $value) $chunks[] = str_replace('%25', '%', urlencode_rfc3986($key) . '="' . urlencode_rfc3986($value) . '"');

        // build return
        $return = 'Authorization: OAuth realm="' . $parts['scheme'] . '://' . $parts['host'] . $parts['path'] . '", ';
        $return .= implode(',', $chunks);

        // prepend name and OAuth part
        return $return;
    }

function urlencode_rfc3986($value)
    {
        if(is_array($value)) return array_map('urlencode_rfc3986', $value);
        else
        {
            $search = array('+', ' ', '%7E', '%');
            $replace = array('%20', '%20', '~', '%25');

            return str_replace($search, $replace, urlencode($value));
        }
    }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM