![](/img/trans.png)
[英]Twitter OAuth: “Failed to validate oauth signature and token” using PHP
[英]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);
有人能看到我可能在這里犯的一個明顯錯誤嗎? 最好不要與其他人一起使用代碼,因為大多數示例都具有完整的類和大量的函數,我正在尋找最簡單的方法!
我遇到了同樣的問題,我所缺少的是將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.