繁体   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