我正在尝试按照Twitter的API来获取用户的关注者列表。
http://api.twitter.com/1.1/followers/ids.json?cursor=-1&screen_name=username
我收到此错误消息作为回应。
{
code = 215;
message = "Bad Authentication data";
}
我似乎无法找到与此错误代码相关的文档。有人对这个错误有任何想法吗?
答案 0 :(得分:23)
没有任何其他php文件的非常简洁的代码包括oauth等。 请注意,要获得以下密钥,您需要使用https://dev.twitter.com注册并创建应用程序。
<?php
$token = 'YOUR_TOKEN';
$token_secret = 'YOUR_TOKEN_SECRET';
$consumer_key = 'CONSUMER_KEY';
$consumer_secret = 'CONSUMER_SECRET';
$host = 'api.twitter.com';
$method = 'GET';
$path = '/1.1/statuses/user_timeline.json'; // api call path
$query = array( // query parameters
'screen_name' => 'twitterapi',
'count' => '5'
);
$oauth = array(
'oauth_consumer_key' => $consumer_key,
'oauth_token' => $token,
'oauth_nonce' => (string)mt_rand(), // a stronger nonce is recommended
'oauth_timestamp' => time(),
'oauth_signature_method' => 'HMAC-SHA1',
'oauth_version' => '1.0'
);
$oauth = array_map("rawurlencode", $oauth); // must be encoded before sorting
$query = array_map("rawurlencode", $query);
$arr = array_merge($oauth, $query); // combine the values THEN sort
asort($arr); // secondary sort (value)
ksort($arr); // primary sort (key)
// http_build_query automatically encodes, but our parameters
// are already encoded, and must be by this point, so we undo
// the encoding step
$querystring = urldecode(http_build_query($arr, '', '&'));
$url = "https://$host$path";
// mash everything together for the text to hash
$base_string = $method."&".rawurlencode($url)."&".rawurlencode($querystring);
// same with the key
$key = rawurlencode($consumer_secret)."&".rawurlencode($token_secret);
// generate the hash
$signature = rawurlencode(base64_encode(hash_hmac('sha1', $base_string, $key, true)));
// this time we're using a normal GET query, and we're only encoding the query params
// (without the oauth params)
$url .= "?".http_build_query($query);
$url=str_replace("&","&",$url); //Patch by @Frewuill
$oauth['oauth_signature'] = $signature; // don't want to abandon all that work!
ksort($oauth); // probably not necessary, but twitter's demo does it
// also not necessary, but twitter's demo does this too
function add_quotes($str) { return '"'.$str.'"'; }
$oauth = array_map("add_quotes", $oauth);
// this is the full value of the Authorization line
$auth = "OAuth " . urldecode(http_build_query($oauth, '', ', '));
// if you're doing post, you need to skip the GET building above
// and instead supply query parameters to CURLOPT_POSTFIELDS
$options = array( CURLOPT_HTTPHEADER => array("Authorization: $auth"),
//CURLOPT_POSTFIELDS => $postfields,
CURLOPT_HEADER => false,
CURLOPT_URL => $url,
CURLOPT_RETURNTRANSFER => true,
CURLOPT_SSL_VERIFYPEER => false);
// do our business
$feed = curl_init();
curl_setopt_array($feed, $options);
$json = curl_exec($feed);
curl_close($feed);
$twitter_data = json_decode($json);
foreach ($twitter_data as &$value) {
$tweetout .= preg_replace("/(http:\/\/|(www\.))(([^\s<]{4,68})[^\s<]*)/", '<a href="http://$2$3" target="_blank">$1$2$4</a>', $value->text);
$tweetout = preg_replace("/@(\w+)/", "<a href=\"http://www.twitter.com/\\1\" target=\"_blank\">@\\1</a>", $tweetout);
$tweetout = preg_replace("/#(\w+)/", "<a href=\"http://search.twitter.com/search?q=\\1\" target=\"_blank\">#\\1</a>", $tweetout);
}
echo $tweetout;
?>
此致
答案 1 :(得分:11)
到目前为止我找到的唯一解决方案是:
使用此令牌,您可以代表用户进行经过身份验证的请求。你可以使用相同的库来完成它。
// Arguments 1 and 2 - your application static tokens, 2 and 3 - user tokens, received from Twitter during authentification
$connection = new TwitterOAuth(TWITTER_CONSUMER_KEY, TWITTER_CONSUMER_SECRET, $tokens['oauth_token'], $tokens['oauth_token_secret']);
$connection->host = 'https://api.twitter.com/1.1/'; // By default library uses API version 1.
$friendsJson = $connection->get('/friends/ids.json?cursor=-1&user_id=34342323');
这将返回用户朋友列表。
答案 2 :(得分:7)
找到一个解决方案 - 使用Abraham TwitterOAuth library。如果您使用的是较旧的实现,则应在实例化新的TwitterOAuth对象后添加以下行:
$connection->host = "https://api.twitter.com/1.1/";
$connection->ssl_verifypeer = TRUE;
$connection->content_type = 'application/x-www-form-urlencoded';
前两行现在记录在亚伯拉罕图书馆自述文件中,但第三行不是。还要确保你的oauth_version仍然是1.0。
这是我的代码,用于从“users / show”获取所有用户数据和新认证的用户,并返回用户的全名和用户图标1.1 - 以下代码在认证回调文件中实现:
session_start();
require ('twitteroauth/twitteroauth.php');
require ('twitteroauth/config.php');
$consumer_key = '****************';
$consumer_secret = '**********************************';
$to = new TwitterOAuth($consumer_key, $consumer_secret);
$tok = $to->getRequestToken('http://exampleredirect.com?twitoa=1');
$token = $tok['oauth_token'];
$secret = $tok['oauth_token_secret'];
//save tokens to session
$_SESSION['ttok'] = $token;
$_SESSION['tsec'] = $secret;
$request_link = $to->getAuthorizeURL($token,TRUE);
header('Location: ' . $request_link);
以下代码在验证和令牌请求后重定向
if($_REQUEST['twitoa']==1){
require ('twitteroauth/twitteroauth.php');
require_once('twitteroauth/config.php');
//Twitter Creds
$consumer_key = '*****************';
$consumer_secret = '************************************';
$oauth_token = $_GET['oauth_token']; //ex Request vals->http://domain.com/twitter_callback.php?oauth_token=MQZFhVRAP6jjsJdTunRYPXoPFzsXXKK0mQS3SxhNXZI&oauth_verifier=A5tYHnAsbxf3DBinZ1dZEj0hPgVdQ6vvjBJYg5UdJI
$ttok = $_SESSION['ttok'];
$tsec = $_SESSION['tsec'];
$to = new TwitterOAuth($consumer_key, $consumer_secret, $ttok, $tsec);
$tok = $to->getAccessToken();
$btok = $tok['oauth_token'];
$bsec = $tok['oauth_token_secret'];
$twit_u_id = $tok['user_id'];
$twit_screen_name = $tok['screen_name'];
//Twitter 1.1 DEBUG
//print_r($tok);
//echo '<br/><br/>';
//print_r($to);
//echo '<br/><br/>';
//echo $btok . '<br/><br/>';
//echo $bsec . '<br/><br/>';
//echo $twit_u_id . '<br/><br/>';
//echo $twit_screen_name . '<br/><br/>';
$twit_screen_name=urlencode($twit_screen_name);
$connection = new TwitterOAuth($consumer_key, $consumer_secret, $btok, $bsec);
$connection->host = "https://api.twitter.com/1.1/";
$connection->ssl_verifypeer = TRUE;
$connection->content_type = 'application/x-www-form-urlencoded';
$ucontent = $connection->get('users/show', array('screen_name' => $twit_screen_name));
//echo 'connection:<br/><br/>';
//print_r($connection);
//echo '<br/><br/>';
//print_r($ucontent);
$t_user_name = $ucontent->name;
$t_user_icon = $ucontent->profile_image_url;
//echo $t_user_name.'<br/><br/>';
//echo $t_user_icon.'<br/><br/>';
}
我花了太长时间才想出这个。希望这有助于某人!!
答案 3 :(得分:5)
<强>更新强> Twitter API 1现已弃用。请参阅上面的答案。
Twitter 1.1无法使用该语法(当我写这个答案时)。需要为1,而不是1.1。这将有效:
http://api.twitter.com/1/followers/ids.json?cursor=-1&screen_name=username
答案 4 :(得分:5)
其中包含/1.1/
的网址是正确的,它是新的Twitter API版本1.1。
但您需要一个应用程序并使用oAuth授权您的应用程序(和用户)。
答案 5 :(得分:5)
Gruik的答案在下面的帖子中为我工作。
{摘录| Zend_Service_Twitter - Make API v1.1 ready}
使用ZF 1.12.3,解决方法是在oauthOptions选项中传递consumerKey和consumerSecret,而不是直接在选项中传递。
$options = array(
'username' => /*...*/,
'accessToken' => /*...*/,
'oauthOptions' => array(
'consumerKey' => /*...*/,
'consumerSecret' => /*...*/,
)
);
答案 6 :(得分:3)
经过两天的研究,我终于找到了访问s.o.公开推文您只需要任何应用程序凭据,而不是那些特定的用户凭据。因此,如果您正在为客户开发,则不必要求他们做任何事情。
要使用新的Twitter API 1.1,您需要做两件事:
首先,您可以(实际上必须)使用您自己的凭据创建应用程序,然后获取访问令牌(OAUTH_TOKEN)和访问令牌密钥< / em>(OAUTH_TOKEN_SECRET)来自“您的访问令牌”部分。 然后,您在新的TwitterOAuth对象的构造函数中提供它们。现在,您可以访问任何人公开推文。
$connection = new TwitterOAuth( CONSUMER_KEY, CONSUMER_SECRET, OAUTH_TOKEN, OAUTH_TOKEN_SECRET );
$connection->host = "https://api.twitter.com/1.1/"; // change the default
$connection->ssl_verifypeer = TRUE;
$connection->content_type = 'application/x-www-form-urlencoded';
$tweets = $connection->get('http://api.twitter.com/1.1/statuses/user_timeline.json?screen_name='.$username.'&count='.$count);
实际上我认为这也是Pavel所提出的建议,但从他的答案来看并不是那么明显。
希望这两天可以拯救其他人:)
答案 7 :(得分:2)
您需要将 customerKey 和 customerSecret 发送给Zend_Service_Twitter
$twitter = new Zend_Service_Twitter(array(
'consumerKey' => $this->consumer_key,
'consumerSecret' => $this->consumer_secret,
'username' => $user->screenName,
'accessToken' => unserialize($user->token)
));
答案 8 :(得分:2)
这可能会帮助使用Zend_Oauth_Client的人使用twitter api。这个工作配置:
$accessToken = new Zend_Oauth_Token_Access();
$accessToken->setToken('accessToken');
$accessToken->setTokenSecret('accessTokenSecret');
$client = $accessToken->getHttpClient(array(
'requestScheme' => Zend_Oauth::REQUEST_SCHEME_HEADER,
'version' => '1.0', // it was 1.1 and I got 215 error.
'signatureMethod' => 'HMAC-SHA1',
'consumerKey' => 'foo',
'consumerSecret' => 'bar',
'requestTokenUrl' => 'https://api.twitter.com/oauth/request_token',
'authorizeUrl' => 'https://api.twitter.com/oauth/authorize',
'accessTokenUrl' => 'https://api.twitter.com/oauth/access_token',
'timeout' => 30
));
看起来twitter api 1.0允许oauth版本为1.1和1.0,其中twitter api 1.1只需要oauth版本为1.0。
P.S我们不使用Zend_Service_Twitter,因为它不允许在状态更新时发送自定义参数。
答案 9 :(得分:0)
确保您对Twitter中的应用程序具有读写访问权限
答案 10 :(得分:0)
我正在使用HybridAuth并遇到连接到Twitter的此错误。我跟踪它(我)向Twitter发送错误的请求类型(获取/发布而不是GET / POST)。
这会导致215:
$call = '/search/tweets.json';
$call_type = 'get';
$call_args = array(
'q' => 'pancakes',
'count' => 5,
);
$response = $provider_api->api( $call, $call_type, $call_args );
这不会:
$call = '/search/tweets.json';
$call_type = 'GET';
$call_args = array(
'q' => 'pancakes',
'count' => 5,
);
$response = $provider_api->api( $call, $call_type, $call_args );
旁注:在HybridAuth的情况下,以下也不会(因为HA内部为请求类型提供了正确的值):
$call = '/search/tweets.json';
$call_args = array(
'q' => 'pancakes',
'count' => 5,
);
$response = $providers['Twitter']->get( $call, $call_args );
答案 11 :(得分:0)
我一直面临着同样的问题,我唯一能解决的问题就是直接在新的TwitterOAuth类定义中输入CONSUMER_SECRET
和$connection = new TwitterOAuth( "MY_CK" , "MY_CS" );
。
List
请勿对此使用变量或静态,并查看问题是否已解决。
答案 12 :(得分:0)
首先,每个人都需要使用 oauth2 / token api,然后使用followers / list api 。
否则,您将得到此错误。因为关注者/列表api需要身份验证。
在迅速(针对移动应用程序)中,我也遇到了同样的问题。
如果您想了解api及其参数,请点击此链接,Get twitter friends list in swift?
答案 13 :(得分:-1)
我知道这已经过时了,但昨天我在使用C#和带有Bearer身份验证令牌的HttpClient类调用此URL时遇到了同样的问题:
http://api.twitter.com/1.1/followers/ids.json?cursor=-1&screen_name=username
事实证明,我的解决方案是使用HTTPS而不是HTTP。所以我的网址看起来像这样:
<强> HTTPS 强>://api.twitter.com/1.1/followers/ids.json光标= -1&安培; SCREEN_NAME =用户名
所以这是我的代码片段:
using (var client = new HttpClient())
{
client.BaseAddress = new Uri("https://api.twitter.com/1.1/");
client.DefaultRequestHeaders.Accept.Clear();
client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
client.DefaultRequestHeaders.Add("Authorization", "Bearer **** YOUR BEARER TOKEN GOES HERE ****");
var response = client.GetAsync("statuses/user_timeline.json?count=10&screen_name=username").Result;
if (!response.IsSuccessStatusCode)
{
return result;
}
var items = response.Content.ReadAsAsync<IEnumerable<dynamic>>().Result;
foreach (dynamic item in items)
{
//Do the needful
}
}
答案 14 :(得分:-1)
试试这个Twitter API explorer,您可以作为开发人员登录并查询您想要的任何内容。