使用Twitter API版本1.1检索user_timeline的最简单PHP示例

由于Twitter API 1.0从2013年6月11日退役,下面的脚本不再工作。

// Create curl resource
$ch = curl_init();
// Set url
curl_setopt($ch, CURLOPT_URL, "http://twitter.com/statuses/user_timeline/myscreenname.json?count=10");
// Return the transfer as a string
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
// $output contains the output string
$output = curl_exec($ch);
// Close curl resource to free up system resources
curl_close($ch);


if ($output)
{
$tweets = json_decode($output,true);


foreach ($tweets as $tweet)
{
print_r($tweet);
}
}

如何用最少的代码获得user_timeline(最近的状态)?

我发现这个:https://dev.twitter.com/docs/api/1.1/get/statuses/user_timeline 但是我得到以下错误:

"{"errors":[{"message":"Could not authenticate you","code":32}]}"

有很多课程,但在尝试了几个之后,它们似乎都没有工作,因为Twitter上的这些更新,加上其中一些是非常高级的课程,有很多功能,我真的不需要。

用PHP获取最近用户状态的最简单/最短的方法是什么?

316422 次浏览

你需要一个在Twitter上创建一个“应用程序”(你需要一个Twitter账户来做这件事)。

然后,你需要使用OAuth向Twitter发出授权请求

你可以使用得到状态/ user_timeline资源来获取最近的tweet列表。

访问dev.twitter.com并创建一个应用程序。这将为您提供所需的证书。下面是我最近用PHP旋度编写的一个实现。

<?php
function buildBaseString($baseURI, $method, $params) {
$r = array();
ksort($params);
foreach($params as $key=>$value){
$r[] = "$key=" . rawurlencode($value);
}
return $method."&" . rawurlencode($baseURI) . '&' . rawurlencode(implode('&', $r));
}


function buildAuthorizationHeader($oauth) {
$r = 'Authorization: OAuth ';
$values = array();
foreach($oauth as $key=>$value)
$values[] = "$key=\"" . rawurlencode($value) . "\"";
$r .= implode(', ', $values);
return $r;
}


$url = "https://api.twitter.com/1.1/statuses/user_timeline.json";


$oauth_access_token = "YOURVALUE";
$oauth_access_token_secret = "YOURVALUE";
$consumer_key = "YOURVALUE";
$consumer_secret = "YOURVALUE";


$oauth = array( 'oauth_consumer_key' => $consumer_key,
'oauth_nonce' => time(),
'oauth_signature_method' => 'HMAC-SHA1',
'oauth_token' => $oauth_access_token,
'oauth_timestamp' => time(),
'oauth_version' => '1.0');


$base_info = buildBaseString($url, 'GET', $oauth);
$composite_key = rawurlencode($consumer_secret) . '&' . rawurlencode($oauth_access_token_secret);
$oauth_signature = base64_encode(hash_hmac('sha1', $base_info, $composite_key, true));
$oauth['oauth_signature'] = $oauth_signature;


// Make requests
$header = array(buildAuthorizationHeader($oauth), 'Expect:');
$options = array( CURLOPT_HTTPHEADER => $header,
//CURLOPT_POSTFIELDS => $postfields,
CURLOPT_HEADER => false,
CURLOPT_URL => $url,
CURLOPT_RETURNTRANSFER => true,
CURLOPT_SSL_VERIFYPEER => false);


$feed = curl_init();
curl_setopt_array($feed, $options);
$json = curl_exec($feed);
curl_close($feed);


$twitter_data = json_decode($json);


//print it out
print_r ($twitter_data);


?>

这可以从命令行运行:

$ php <name of PHP script>.php

Rivers粘贴的代码很棒。非常感谢!我是新来的,不能评论,我只想回答来自javiervd的问题(你如何设置screen_name和这种方法的计数?),因为我已经浪费了很多时间来弄清楚。

你需要将参数添加到URL和签名创建过程中。 创建签名是帮助我的文章。这是我的代码:

$oauth = array(
'screen_name' => 'DwightHoward',
'count' => 2,
'oauth_consumer_key' => $consumer_key,
'oauth_nonce' => time(),
'oauth_signature_method' => 'HMAC-SHA1',
'oauth_token' => $oauth_access_token,
'oauth_timestamp' => time(),
'oauth_version' => '1.0'
);


$options = array(
CURLOPT_HTTPHEADER => $header,
//CURLOPT_POSTFIELDS => $postfields,
CURLOPT_HEADER => false,
CURLOPT_URL => $url . '?screen_name=DwightHoward&count=2',
CURLOPT_RETURNTRANSFER => true, CURLOPT_SSL_VERIFYPEER => false
);

从2018年年中开始,获得twitter API令牌的过程变得更加官僚。它已经采取了我在一个工作周提供了一组API令牌,这是一个开源项目为你们男孩和女孩在Packagist上超过120万安装量和1.6k星在Github上,理论上应该是更高的优先级。

如果您的任务是在工作中使用twitter API,那么您必须考虑到这个可能非常长的等待时间。还可以考虑其他社交媒体渠道,如Facebook或Instagram,并提供这些选项,因为检索他们的代币的过程是即时的。


所以您想使用Twitter v1.1 API?

注意:这些文件都在GitHub上

版本1.0 将很快被弃用和未经授权的请求将不被允许。因此,这里有一篇文章可以帮助您做到这一点,并提供了一个PHP类,使您的工作更轻松。

在Twitter上创建自己的开发者账户

您需要访问Twitter官方开发者网站并注册一个开发者帐户。 这是一个免费的,是为v1.1 API发出请求的必要步骤

在Twitter开发者网站上创建一个应用程序

< p >什么?你以为你可以发出未经验证的请求吗?Twitter的v1.1 API不是这样的。 你需要访问http://dev.twitter.com/apps,然后点击“创建应用程序”。按钮。< / p >

Enter image description here

在这一页上,你想填什么细节就填什么。对我来说,这并不重要,因为我只是想发出大量的屏蔽请求来摆脱垃圾邮件关注者。关键是你要让自己的一组唯一的键用于你的应用程序。

因此,创建应用程序的重点是为自己(和Twitter)提供一组密钥。这些都是:

  • 消费者的钥匙
  • 消费者的秘密
  • 访问令牌
  • 访问令牌秘密

这里有一些信息在这里关于这些令牌的用途。

3.创建访问令牌:你将需要这些成功的请求

OAuth请求一些令牌。所以你需要为你生成它们。

Enter image description here

点击“创建我的访问令牌”;在底部。然后再次滚动到底部,就会有一些新生成的键。你需要从这个页面为你的API调用抓取之前标记的四个键,所以在某个地方记下它们。

4. 更改访问级别:你不想只读,是吗?

如果你想更好地使用这个API,你需要将你的设置改为Read &如果你正在使用得到请求做标准数据检索以外的事情,请写。

Enter image description here

选择“设置”;标签靠近页面顶部。

Enter image description here

给你的应用程序读写权限,然后点击“更新”;在底部。

你可以阅读有关应用程序权限模型的更多信息, Twitter使用这里。


大部分都是我帮你做的

我将上面的代码(经过一些修改和更改)合并到一个PHP类中,这样就可以非常简单地发出所需的请求。

这使用了OAuthTwitter v1.1 API,以及我已经创建的类,你可以在下面找到。

require_once('TwitterAPIExchange.php');


/** Set access tokens here - see: https://dev.twitter.com/apps/ **/
$settings = array(
'oauth_access_token' => "YOUR_OAUTH_ACCESS_TOKEN",
'oauth_access_token_secret' => "YOUR_OAUTH_ACCESS_TOKEN_SECRET",
'consumer_key' => "YOUR_CONSUMER_KEY",
'consumer_secret' => "YOUR_CONSUMER_SECRET"
);

确保将从应用程序中获得的键放在上面各自的位置。

接下来,您需要选择一个要向其发出请求的URL。Twitter有他们的API文档来帮助你选择URL和请求类型(POST或GET)。

/** URL for REST request, see: https://dev.twitter.com/docs/api/1.1/ **/
$url = 'https://api.twitter.com/1.1/blocks/create.json';
$requestMethod = 'POST';

在文档中,每个URL都说明了可以传递给它的内容。如果我们使用&;block &;类似于上面的URL,我可以传递以下POST参数:

/** POST fields required by the URL above. See relevant docs as above **/
$postfields = array(
'screen_name' => 'usernameToBlock',
'skip_status' => '1'
);

现在您已经设置了要使用API做的事情,接下来是发出实际请求的时候了。

/** Perform the request and echo the response **/
$twitter = new TwitterAPIExchange($settings);
echo $twitter->buildOauth($url, $requestMethod)
->setPostfields($postfields)
->performRequest();

对于POST请求,就是这样!

对于得到请求,略有不同。这里有一个例子:

/** Note: Set the GET field BEFORE calling buildOauth(); **/
$url = 'https://api.twitter.com/1.1/followers/ids.json';
$getfield = '?username=J7mbo';
$requestMethod = 'GET';
$twitter = new TwitterAPIExchange($settings);
echo $twitter->setGetfield($getfield)
->buildOauth($url, $requestMethod)
->performRequest();

最终代码示例:对于我的追随者列表的一个简单的GET请求。

$url = 'https://api.twitter.com/1.1/followers/list.json';
$getfield = '?username=J7mbo&skip_status=1';
$requestMethod = 'GET';
$twitter = new TwitterAPIExchange($settings);
echo $twitter->setGetfield($getfield)
->buildOauth($url, $requestMethod)
->performRequest();

我把这些文件放在GitHub上归功于@lackovic10和@rivers!我希望有人觉得它有用;我知道我做到了(我在循环中使用它进行批量阻塞)。

此外,对于那些在Windows上遇到SSL证书问题的人,请查看这篇文章。这个库在底层使用cURL,所以你需要确保你已经设置了cURL certs。谷歌也是你的朋友。

这个问题对我帮助很大,但并没有让我完全理解需要发生什么。这篇博文做了一个惊人的工作,引导我通过它。

以下是所有重要的部分:

  • 如上所述,您必须签署您的1.1 API请求。如果您正在执行诸如获取公共状态之类的操作,那么您将需要一个应用程序密钥而不是用户密钥。你想要的页面的完整链接是:https://dev.twitter.com/apps
  • 你必须散列所有的参数,包括oauth参数和get参数(或POST参数)。
  • 必须先对参数进行排序,然后再将它们缩减为url编码的表单,然后进行散列。
  • 您必须多次编码某些内容—例如,您从参数的url编码值创建一个查询字符串,然后对其进行url编码,并将其与方法类型和url连接起来。

我同情所有这些令人头痛的问题,所以这里有一些代码来总结:

$token = 'YOUR TOKEN';
$token_secret = 'TOKEN SECRET';
$consumer_key = 'YOUR KEY';
$consumer_secret = 'KEY 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' => '2'
);


$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);


$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);

如果安装了OAuth PHP库,就不必担心自己生成请求。

$oauth = new OAuth($consumer_key, $consumer_secret, OAUTH_SIG_METHOD_HMACSHA1, OAUTH_AUTH_TYPE_URI);
$oauth->setToken($access_token, $access_secret);


$oauth->fetch("https://api.twitter.com/1.1/statuses/user_timeline.json");
$twitter_data = json_decode($oauth->getLastResponse());


print_r($twitter_data);

有关更多信息,请查看文档或它们的例子。你可以使用pecl install oauth来获取库。

谢谢你,克里斯!

它为我工作,没有使用参数的查询,每当我使用多个参数时,它向我显示错误:32无法验证您。

对我来说,问题在于&号编码。在你的代码中,就是下面这行

$url .= "?".http_build_query($query);

我在下面添加了如下一行:

$url=str_replace("&amp;","&",$url);

它使用两个或多个参数,如screen_name和count。

整个代码是这样的:

$token = 'YOUR TOKEN';
$token_secret = 'TOKEN SECRET';
$consumer_key = 'YOUR KEY';
$consumer_secret = 'KEY 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' => '2'
);


$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("&amp;","&",$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);

希望它能帮助到和我有同样问题的人。

就像在其他答案中所说的,创建一个Twitter应用程序来获得令牌,密钥和秘密。 使用下面的代码,你可以从一个点修改请求参数,避免输入错误和类似的错误(在returnTweet()函数中更改$request数组)
function buildBaseString($baseURI, $method, $params) {
$r = array();
ksort($params);
foreach($params as $key=>$value){
$r[] = "$key=" . rawurlencode($value);
}
return $method."&" . rawurlencode($baseURI) . '&' . rawurlencode(implode('&', $r));
}


function buildAuthorizationHeader($oauth) {
$r = 'Authorization: OAuth ';
$values = array();
foreach($oauth as $key=>$value)
$values[] = "$key=\"" . rawurlencode($value) . "\"";
$r .= implode(', ', $values);
return $r;
}


function returnTweet(){
$oauth_access_token         = "x";
$oauth_access_token_secret  = "x";
$consumer_key               = "x";
$consumer_secret            = "x";


$twitter_timeline           = "user_timeline";  //  mentions_timeline / user_timeline / home_timeline / retweets_of_me


//  create request
$request = array(
'screen_name'       => 'budidino',
'count'             => '3'
);


$oauth = array(
'oauth_consumer_key'        => $consumer_key,
'oauth_nonce'               => time(),
'oauth_signature_method'    => 'HMAC-SHA1',
'oauth_token'               => $oauth_access_token,
'oauth_timestamp'           => time(),
'oauth_version'             => '1.0'
);


//  merge request and oauth to one array
$oauth = array_merge($oauth, $request);


//  do some magic
$base_info              = buildBaseString("https://api.twitter.com/1.1/statuses/$twitter_timeline.json", 'GET', $oauth);
$composite_key          = rawurlencode($consumer_secret) . '&' . rawurlencode($oauth_access_token_secret);
$oauth_signature            = base64_encode(hash_hmac('sha1', $base_info, $composite_key, true));
$oauth['oauth_signature']   = $oauth_signature;


//  make request
$header = array(buildAuthorizationHeader($oauth), 'Expect:');
$options = array( CURLOPT_HTTPHEADER => $header,
CURLOPT_HEADER => false,
CURLOPT_URL => "https://api.twitter.com/1.1/statuses/$twitter_timeline.json?". http_build_query($request),
CURLOPT_RETURNTRANSFER => true,
CURLOPT_SSL_VERIFYPEER => false);


$feed = curl_init();
curl_setopt_array($feed, $options);
$json = curl_exec($feed);
curl_close($feed);


return json_decode($json, true);
}

然后调用returnTweet()

首先我要感谢jimbo和(他的帖子 / twitter-api-php简单库)。

如果你打算使用GET搜索/tweet API和"twitter-api-php" PHP库(TwitterAPIExchange.php):

首先,您必须注释“执行POST请求并回显响应”代码区域。

只需使用“执行GET请求并回显响应”代码并回显响应并更改这两行:

$url = 'https://api.twitter.com/1.1/followers/ids.json';
$getfield = '?screen_name=J7mbo';

$url = 'https://api.twitter.com/1.1/search/tweets.json';
$getfield = '?q=J7mbo';

(将screen_name改为q,就是这样:)

$connection = new TwitterOAuth(CONSUMER_KEY, CONSUMER_SECRET, OAUTH_TOKEN, OAUTH_TOKEN_SECRET);


$timelines = $connection->get('statuses/user_timeline', array('screen_name' => 'NSE_NIFTY', 'count' => 100, 'include_rts' => 1));

感谢这个线程,尤其是budidino,因为他的代码是什么让我回家。 只是想贡献一下如何从请求中检索JSON数据。 更改“//create request”请求数组部分的代码以执行不同的请求。最终,这将把JSON输出到浏览器屏幕

<?php
function buildBaseString($baseURI, $method, $params) {
$r = array();
ksort($params);
foreach($params as $key=>$value){
$r[] = "$key=" . rawurlencode($value);
}
return $method."&" . rawurlencode($baseURI) . '&' . rawurlencode(implode('&', $r));
}


function buildAuthorizationHeader($oauth) {
$r = 'Authorization: OAuth ';
$values = array();
foreach($oauth as $key=>$value)
$values[] = "$key=\"" . rawurlencode($value) . "\"";
$r .= implode(', ', $values);
return $r;
}


function returnTweet(){
$oauth_access_token         = "2602299919-lP6mgkqAMVwvHM1L0Cplw8idxJzvuZoQRzyMkOx";
$oauth_access_token_secret  = "wGWny2kz67hGdnLe3Uuy63YZs4nIGs8wQtCU7KnOT5brS";
$consumer_key               = "zAzJRrPOj5BvOsK5QhscKogVQ";
$consumer_secret            = "Uag0ujVJomqPbfdoR2UAWbRYhjzgoU9jeo7qfZHCxR6a6ozcu1";


$twitter_timeline           = "user_timeline";  //  mentions_timeline / user_timeline / home_timeline / retweets_of_me


//  create request
$request = array(
'screen_name'       => 'burownrice',
'count'             => '3'
);


$oauth = array(
'oauth_consumer_key'        => $consumer_key,
'oauth_nonce'               => time(),
'oauth_signature_method'    => 'HMAC-SHA1',
'oauth_token'               => $oauth_access_token,
'oauth_timestamp'           => time(),
'oauth_version'             => '1.0'
);


//  merge request and oauth to one array
$oauth = array_merge($oauth, $request);


//  do some magic
$base_info              = buildBaseString("https://api.twitter.com/1.1/statuses/$twitter_timeline.json", 'GET', $oauth);
$composite_key          = rawurlencode($consumer_secret) . '&' . rawurlencode($oauth_access_token_secret);
$oauth_signature            = base64_encode(hash_hmac('sha1', $base_info, $composite_key, true));
$oauth['oauth_signature']   = $oauth_signature;


//  make request
$header = array(buildAuthorizationHeader($oauth), 'Expect:');
$options = array( CURLOPT_HTTPHEADER => $header,
CURLOPT_HEADER => false,
CURLOPT_URL => "https://api.twitter.com/1.1/statuses/$twitter_timeline.json?". http_build_query($request),
CURLOPT_RETURNTRANSFER => true,
CURLOPT_SSL_VERIFYPEER => false);


$feed = curl_init();
curl_setopt_array($feed, $options);
$json = curl_exec($feed);
curl_close($feed);


return $json;
}


$tweet = returnTweet();
echo $tweet;


?>

下面是一个简单的从你的时间轴上获得指定数量的推文的方法。它的功能与其他示例基本相同,只是使用了更少的代码。

只需要填入键并根据你的喜好调整$count:

$url = 'https://api.twitter.com/1.1/statuses/user_timeline.json';
$count = '10';


$oauth = array('count' => $count,
'oauth_consumer_key' => '[CONSUMER KEY]',
'oauth_nonce' => md5(mt_rand()),
'oauth_signature_method' => 'HMAC-SHA1',
'oauth_timestamp' => time(),
'oauth_token' => '[ACCESS TOKEN]',
'oauth_version' => '1.0');


$oauth['oauth_signature'] = base64_encode(hash_hmac('sha1', 'GET&' . rawurlencode($url) . '&' . rawurlencode(implode('&', array_map(function ($v, $k) { return $k . '=' . $v; }, $oauth, array_keys($oauth)))), '[CONSUMER SECRET]&[ACCESS TOKEN SECRET]', true));


$twitterData = json_decode(file_get_contents($url . '?count=' . $count, false, stream_context_create(array('http' => array('method' => 'GET',
'header' => 'Authorization: OAuth '
. implode(', ', array_map(function ($v, $k) { return $k . '="' . rawurlencode($v) . '"'; }, $oauth, array_keys($oauth))))))));

这个函数使用匿名函数和file_get_contents来代替cURL库。注意使用MD5散列nonce。每个人似乎都暂时同意time(),然而,网络上关于OAuth的大多数示例使用某种加密字符串(就像这个:http://www.sitepoint.com/understanding-oauth-1/)。这对我来说也更有意义。

进一步的注意:你需要PHP 5.3+匿名函数(以防你的服务器/计算机在冷战洞穴里,你不能升级它)。

从它们的签名发电机,你可以生成如下形式的curl命令:

curl --get 'https://api.twitter.com/1.1/statuses/user_timeline.json' --data 'count=2&screen_name=twitterapi' --header 'Authorization: OAuth oauth_consumer_key="YOUR_KEY", oauth_nonce="YOUR_NONCE", oauth_signature="YOUR-SIG", oauth_signature_method="HMAC-SHA1", oauth_timestamp="TIMESTAMP", oauth_token="YOUR-TOKEN", oauth_version="1.0"' --verbose

如果它对任何人都有用… 在我的博客中,我实现了下面的PHP代码,以便检索最近的tweet,提取最相关的数据,然后将它们保存到MySQL数据库中。

存储它们的“tweets”表:

CREATE TABLE IF NOT EXISTS `tweets` (
`tweet_id` int(11) NOT NULL auto_increment,
`id_tweet` bigint(20) NOT NULL,
`text_tweet` char(144) NOT NULL,
`datetime_tweet` datetime NOT NULL,
`dayofweek_tweet` char(3) NOT NULL,
`GMT_tweet` char(5) NOT NULL,
`shorturl_tweet` char(23) NOT NULL,
PRIMARY KEY  (`tweet_id`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8 AUTO_INCREMENT=83 ;

get_tweets.php:

<?php
function buildBaseString($baseURI, $method, $params) {
$r= array();
ksort($params);
foreach($params as $key=>$value){
$r[]= "$key=".rawurlencode($value);
}
return $method."&".rawurlencode($baseURI).'&'.rawurlencode(implode('&', $r));
}


function buildAuthorizationHeader($oauth) {
$r= 'Authorization: OAuth ';
$values= array();
foreach($oauth as $key=>$value) {
$values[]= "$key=\"".rawurlencode($value)."\"";
}
$r.= implode(', ', $values);
return $r;
}


function returnTweets($last_id) {
$oauth_access_token         = "2687912757-vbyfJA483SEyj2HJ2K346aVMxtOIgVbsY4Edrsw";
$oauth_access_token_secret  = "nIruzmR0bXqC3has4fTf8KAq4pgOceiuKqjklhroENU4W";
$api_key                    = "ieDSTFH8QHHPafg7H0whQB9GaY";
$api_secret                 = "mgm8wVS9YP93IJmTQtsmR8ZJADDNdlTca5kCizMkC7O7gFDS1j";
$twitter_timeline           = "user_timeline";  //[mentions_timeline/user_timeline/home_timeline/retweets_of_me]
//create request
$request= array(
'screen_name'       => 'runs_ES',
'count'             => '3',
'exclude_replies'   => 'true'
);
if (!is_null($last_id)) { //Add to the request if it exits a last_id
$request['since_id']= $max_id;
}
$oauth = array(
'oauth_consumer_key'        => $api_key,
'oauth_nonce'               => time(),
'oauth_signature_method'    => 'HMAC-SHA1',
'oauth_token'               => $oauth_access_token,
'oauth_timestamp'           => time(),
'oauth_version'             => '1.0'
);
//merge request and oauth to one array
$oauth= array_merge($oauth, $request);
//do some magic
$base_info=                 buildBaseString("https://api.twitter.com/1.1/statuses/$twitter_timeline.json", 'GET', $oauth);
$composite_key=             rawurlencode($api_secret).'&'.rawurlencode($oauth_access_token_secret);
$oauth_signature=           base64_encode(hash_hmac('sha1', $base_info, $composite_key, true));
$oauth['oauth_signature']=  $oauth_signature;
//make request
$header= array(buildAuthorizationHeader($oauth), 'Expect:');
$options= array(CURLOPT_HTTPHEADER => $header,
CURLOPT_HEADER => false,
CURLOPT_URL => "https://api.twitter.com/1.1/statuses/$twitter_timeline.json?". http_build_query($request),
CURLOPT_RETURNTRANSFER => true,
CURLOPT_SSL_VERIFYPEER => false);
$feed= curl_init();
curl_setopt_array($feed, $options);
$json= curl_exec($feed);
curl_close($feed);
return $json;
}


function parse_tweettext($tweet_text) {
$text= substr($tweet_text, 0, -23);
$short_url= substr($tweet_text, -23, 23);
return array ('text'=>$text, 'short_url'=> $short_url);
}


function parse_tweetdatetime($tweetdatetime) {
//Thu Aug 21 21:57:26 +0000 2014 Sun Mon Tue Wed Thu Fri Sat
$months= array('Jan'=>'01', 'Feb'=>'02', 'Mar'=>'03', 'Apr'=>'04', 'May'=>'05', 'Jun'=>'06',
'Jul'=>'07', 'Aug'=>'08', 'Sep'=>'09', 'Oct'=>'10', 'Nov'=>'11', 'Dec'=>'12');
$GMT= substr($tweetdatetime, -10, 5);
$year= substr($tweetdatetime, -4, 4);
$month_str= substr($tweetdatetime, 4, 3);
$month= $months[$month_str];
$day= substr($tweetdatetime, 8, 2);
$dayofweek= substr($tweetdatetime, 0, 3);
$time= substr($tweetdatetime, 11, 8);
$date= $year.'-'.$month.'-'.$day;
$datetime= $date.' '.$time;
return array('datetime'=>$datetime, 'dayofweek'=>$dayofweek, 'GMT'=>$GMT);
//datetime: "YYYY-MM-DD HH:MM:SS", dayofweek: Mon, Tue..., GMT: +####
}


//First check in the database the last id tweet:
$query= "SELECT MAX(tweets.id_tweet) AS id_last FROM tweets;";
$result= exec_query($query);
$row= mysql_fetch_object($result);
if ($result!= 0 && mysql_num_rows($result)) { //if error in query or not results
$last_id= $row->id_last;
}
else {
$last_id= null;
}


$json= returnTweets($last_id);
$tweets= json_decode($json, TRUE);


foreach ($tweets as $tweet) {
$tweet_id= $tweet['id'];
if (!empty($tweet_id)) { //if array is not empty
$tweet_parsetext= parse_tweettext($tweet['text']);
$tweet_text= utf8_encode($tweet_parsetext['text']);
$tweet_shorturl= $tweet_parsetext['short_url'];
$tweet_parsedt= parse_tweetdatetime($tweet['created_at']);
$tweet_datetime= $tweet_parsedt['datetime'];
$tweet_dayofweek= $tweet_parsedt['dayofweek'];
$tweet_GMT= $tweet_parsedt['GMT'];
//Insert the tweet into the database:
$fields = array(
'id_tweet' => $tweet_id,
'text_tweet' => $tweet_text,
'datetime_tweet' => $tweet_datetime,
'dayofweek_tweet' => $tweet_dayofweek,
'GMT_tweet' => $tweet_GMT,
'shorturl_tweet' => $tweet_shorturl
);
$new_id= mysql_insert('tweets', $fields);
}
} //end of foreach
?>

保存推文功能:

function mysql_insert($table, $inserts) {
$keys = array_keys($inserts);
exec_query("START TRANSACTION;");
$query= 'INSERT INTO `'.$table.'` (`'.implode('`,`', $keys).'`) VALUES (\''.implode('\',\'', $inserts).'\')';
exec_query($query);
$id= mysql_insert_id();
if (mysql_error()) {
exec_query("ROLLBACK;");
die("Error: $query");
}
else {
exec_query("COMMIT;");
}
return $id;
}