![](/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.