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


292

由于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获取最近的用户状态的最简单/最快捷的方法是什么?


97
我会杀了这个答案。他们的文件非常糟糕。
RCNeil 2012年

我是Twitter API的新手,并在其中苦苦挣扎。我发现自己使用了不赞成使用的代码。
安东尼


@马克谢谢马克!那很简单!!最初这对我不起作用。我正在运行WAMP。我不得不做出改变,以我的php.ini在我的Apache目录根据这个线索: stackoverflow.com/questions/5444249/...
Adlin玲

1
我只是写下解决方案,没有卷曲或任何其他额外的库:stackoverflow.com/questions/17049821/...
Rauli Rajande

Answers:


820

重要说明:截至2018年中,获取Twitter API令牌的过程变得官僚主义得多。我花了一个多星期的时间才能提供一套API令牌,这是为你们的一个开源项目,在Packagist上安装了超过120万个安装,在Github上安装了1.6k个星,从理论上讲应该是更高的优先级。

如果您的任务是使用Twitter API进行工作,则必须考虑到这个可能非常长的等待时间。还应考虑其他社交媒体渠道,例如Facebook或Instagram,并提供这些选项,因为检索其令牌的过程是即时的。


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

注意:这些文件位于GitHub上

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

1.创建一个开发人员帐户:在Twitter上设置一个开发人员帐户

您需要访问官方Twitter开发人员站点并注册一个开发人员帐户。这是一个免费的和必要的步骤,以便为1.1版API请求。

2.创建一个应用程序:在Twitter开发人员站点上创建一个应用程序

什么?您以为可以发出未经身份验证的请求?不适用于Twitter的v1.1 API。您需要访问http://dev.twitter.com/apps并单击“创建应用程序”按钮。

在此处输入图片说明

在此页面上,填写所需的任何详细信息。对我而言,这并不重要,因为我只想发出大量阻止请求来摆脱垃圾邮件跟踪者。关键是您将获得一套可以用于您的应用程序的唯一键

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

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

还有的一点点信息在这里关于这些令牌。

3.创建访问令牌:您需要使用这些令牌才能成功进行请求

OAuth请求一些令牌。因此,您需要为您生成它们。

在此处输入图片说明

点击底部的“创建我的访问令牌”。然后,再次滚动到底部时,您将拥有一些新生成的键。您需要从该页面上抓取四个以前标记的键来进行API调用,因此请在某处记下它们。

4.更改访问级别:您不希望只读,对吗?

如果您想充分利用此API,则除了使用GET请求进行标准数据检索外,还需要将设置更改为“读写” 。

在此处输入图片说明

选择页面顶部附近的“设置”标签。

在此处输入图片说明

授予您的应用程序读/写访问权限,然后单击底部的“更新”。

您可以在此处阅读有关 Twitter使用的应用程序许可权模型的更多信息


5.编写代码以访问API:我已经为您完成了大部分工作

我将上面的代码(进行了一些修改和更改)组合到一个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都说明了可以传递给它的内容。如果我们像上面那样使用“ blocks” 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请求,就是这样!

对于GET请求,情况有所不同。这是一个例子:

/** 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证书。Google也是您的朋友。


4
@kaffolder该页面上的链接:profilepicture.co.uk/caching-api-responses-php提出了一种简单的方法。您在第一个请求上将twitter数据写入文件或数据库(MySQL或MongoDB),然后在随后的每个请求中,根据所需的文件时间限制检查当前时间(可以将文件命名为时间限制),并且如果文件存在并且文件名在所需的时间限制内,则提取数据而不执行API请求。如果文件存在但已超过时间限制,请删除文件,然后执行API请求。
Jimbo 2013年

7
返回后,我不知道如何处理json数据。我不想像在echo $ twitter-> setGetfield($ getfield)-> buildOauth($ url,$ requestMethod)-> performRequest();中那样将其回显到屏幕上。抱歉,我不知道如何进行换行!我想做类似$ jsonData = json_decode($ twitter);的事情。但它不起作用-我觉得我缺少基本的东西,但一分钱都没有下降……
Ashley

67
谢谢,Twitter的文档杂乱无章,对您大有帮助。
joren

7
使此类在Windows上运行有很多先决条件。你需要有一个工作版本的卷曲装在你的php.ini文件,还需要加载CA证书在你php.ini使用的文件curl.cainfo = path\to\cacert.pem。您可以在此处获取CA证书。
Jake Z

4
@Jimbo我只是注意到一些默认的cURL扩展名在Windows中存在错误,需要替换(因此需要链接到“固定”版本的链接),并且在不加载CA证书的情况下,您的类将返回false,如curl_error()报告“ SSL证书问题,请验证CA证书是否正常”。可以通过关闭CURLOPT_SSL_VERIFYPEER来避免这种情况,但是我认为我将包括实际使用CA证书的基本说明。只是包含此内容可能节省一些人几分钟的搜索时间。
Jake Z

137

转到dev.twitter.com并创建一个应用程序。这将为您提供所需的凭据。这是我最近用PHPcURL编写的实现。

<?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

2
感谢您提供的代码段,可以正常工作。唯一的问题是我似乎无法弄清楚如何设置帖子计数回报。它只返回20,而我要按照Twitter限制全额支付200。
Flatlyn

23
您将如何设置screen_namecount方法?我尝试将其添加到$url变量中,但出现“无法验证您”错误。
哈维尔·维拉纽瓦

1
这段代码很棒!我正在尝试对其进行修改以使用search / tweets.json api,但是我总是收到响应“无法验证您的身份”-有什么想法吗?
克里斯(Chris

1
这篇文章非常有帮助。我的代码似乎没有从中返回curl_init()。我看过一些示例,它们看起来非常简单明了,就像这里的代码一样。我需要安装一些特殊的东西吗?
jessicaraygun

1
它为我工作了2016年10月26日。输出比我预期的要复杂一些。
JohnC

61

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

2
我不能足够投票。在Twitter的API文档中,这使您面目全非,但从来都不是超级“显而易见的”。这种方法会干扰buildAuthorizationHeader功能吗?我单独实施了它。
Moe 2013年

我已经为此工作了很长时间,所以我不记得了,如果您还没有解决您的问题,那么我将在接下来的几天内进行调查。
missingovic10 2014年

我一直在尝试使您的解决方案适应于在statuss / update.json上执行POST的过程,但是运气不好,您是否知道如何实现此目标?
perrohunter 2014年

1
@perrohunter我不知道必须对此进行更多研究。如果您在几天之内找不到方法,请给我发送邮件,我会尽力帮助您。
不足维克10年

18

像其他答案中所述,创建一个Twitter应用程序以获取令牌,密钥和机密。使用下面的代码,您可以从一个位置修改请求参数,避免输入错误和类似错误(更改功能中的$request数组returnTweet())。

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()


1
很棒的工作@budidino!在dev.twitter.com/apps上创建了应用程序,并用oauth_access_token,oauth_access_token_secret,consumer_key,consumer_secret填充了x。*注意*您需要按“创建我的访问令牌”,这需要几秒钟的时间才能生成,因此请等待。
Theo

@budidino dnt我们需要包括任何库?
anam 2014年

我填写了密钥,将其添加到functions.phpWordPress中的文件中,放入<?php echo returnTweet(); ?>HTML文件中,然后输出单词“ Array”,除此之外没有其他内容。
2014年

@Desi,结果是tweets数组,您应该处理如何显示它们。尝试print_r(returnTweet())只是为了看看里面有什么。看看显示所有推文的示例:gist.github.com/budidino/9681764#file-stackoverflow-returntweet
budidino 2014年

1
如果只想获取最新的tweet,则应修改$ request数组并将count设置为1。假设您使用$ tweet = returnTweet();。然后,如果要显示最新的tweet(在本例中为唯一的tweet),则可以编写如下内容:echo“ latest tweet:”。$ tweet [0] [“ text”]; 如果您想提取的不仅仅是推文的文本,请务必检查Twitter返回的结构(例如$ userProfileImageURL = $ tweet [0] [“ user”] [“ profile_image_url”])。dev.twitter.com/docs/api/1.1/get/statuses/user_timeline
budidino 2014年

16

谢谢克里斯!

当我使用多个参数时,它向我显示错误: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);

希望它可以帮助遇到我同样问题的人。


非常感谢,您的代码改进效果很好!一个问题是:“ //建议使用更强的随机数”。那会是什么呢?时间()?
塞巴斯蒂安

感谢您指出了这一点。塞巴斯蒂安(Sebastian):随机数是一次性使用的令牌,应该在密码上安全。mt_rand()太短(32位),而且不是加密的PRNG。从理论上讲,这会使oauth令牌变得脆弱,但是为了简化我的原始示例代码,我想使用PHP附带的,易于理解的东西。
克里斯·里夫斯

收到错误32。无法验证您的身份。我用过您上面的代码
saadk '16

@frewuill,您真棒,我的魅力十足,谢谢。
vijay

9

这个问题对我有很大帮助,但并不能帮助我理解发生的一切。这篇博文为我提供了出色的工作。

以下是所有重要的地方:

  • 如上所述,您必须签署1.1 API请求。如果您正在做类似获取公共状态的操作,则需要一个应用程序密钥而不是用户密钥。所需页面的完整链接是:https : //dev.twitter.com/apps
  • 您必须一起哈希所有参数,包括oauth参数和get参数(或POST参数)。
  • 您必须先对参数进行排序,然后再将其缩减为经过哈希处理的url编码形式。
  • 您必须多次对某些事物进行编码-例如,从参数的url编码值创建查询字符串,然后对THAT进行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);

6

如果您安装了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);

有关更多信息,请查看docs或其示例。您可以pecl install oauth用来获取库。


5

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

如果要将GET搜索/推文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_nameq,就这样:)


我还是没有运气:/
里卡多(Ricardo)2013年

2

您需要在Twitter上创建一个“应用程序”(并且您需要一个Twitter帐户)。

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

您可以使用GET statuses / user_timeline资源获取最近的推文列表。


4
请给我们愚蠢的人解释一下。您所提供的见解与文档一样多,甚至更多。您是否HttpRequest()在步骤2中使用了PHP的功能?亚伯拉罕的TwitterOAuth PHP-github.com/abraham/twitteroauth-库也应该执行此操作,但实际上并未提供实现它的示例。
RCNeil 2012年


2
@MatthewRapati页面丢失。
RN库什瓦哈2015年

0

这是一个简短的提示,用于从时间轴中获取指定数量的推文。基本上,它与其他示例具有相同的功能,只需要较少的代码。

只需填写密钥并$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哈希随机数。每个人似乎都time()随波逐流,但是,网络上有关OAuth的大多数示例都使用某种加密的字符串(例如:http//www.sitepoint.com/understanding-oauth-1/)。这对我来说也更有意义。

进一步说明:匿名功能需要PHP 5.3+(以防服务器/计算机陷入冷战,并且无法升级)。


-1

从他们的签名生成器,您可以生成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

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

3
请提供有关此代码的作用的说明,以便OP可以从中学习。
Cerbrus 2014年

-2

多亏了这个线程,尤其是budidino,因为他的代码才使我成家。只是想贡献如何从请求中检索JSON数据。对代码的“ //创建请求”请求数组进行更改,以执行不同的请求。最终,这会将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;

?>

-2

如果对任何人有用...在我的博客中,我实现了以下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;
}

“它之所以有效是因为我在博客中找到了它”是我的最爱之一。您的帖子未回答实际问题。您正在使用的php代码质量也很差。在此处阅读phptherightway.com。特别是关于DB
Maciej Paprocki

另外,您还公开了所有密钥和令牌,因此,如果有人拿走它并入侵您的Twitter帐户,不要感到惊讶!
garrettlynch
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.