ChatGPT解决这个技术问题 Extra ChatGPT

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

由于自 June 11th 2013 起 Twitter API 1.0 停用,下面的脚本不再工作。

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

我会杀死这个答案。他们的文档非常糟糕。
我是 Twitter API 的新手,并且有点挣扎。我发现自己使用了已弃用的代码。
@马克谢谢马克!!那很简单!!这最初对我不起作用。我正在运行 WAMP。我不得不根据这个线程对我的 Apache 目录中的 php.ini 进行更改:stackoverflow.com/questions/5444249/…
我刚刚写下了没有 CURL 或任何其他额外库的解决方案:stackoverflow.com/questions/17049821/…

C
Community

重要提示:截至 2018 年年中,获取 twitter API 令牌的过程变得更加官僚化。我花了一个多星期的时间才获得一组 API 令牌,这是一个开源项目,适用于你们在 Packagist 上安装超过 120 万,在 Github 上安装了 1.6k 星,理论上应该更高优先级.如果您的任务是使用 twitter API 进行工作,则必须考虑到这个潜在的极长等待时间。还可以考虑其他社交媒体渠道,例如 Facebook 或 Instagram,并提供这些选项,因为检索其代币的过程是即时的。

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

Note: the files for these are on GitHub

不允许 1.0 will soon be deprecated 版和未经授权的请求。所以,这里有一篇文章可以帮助你做到这一点,还有一个 PHP 类可以让你的生活更轻松。

1. 创建开发者账号:在 Twitter 上为自己设置一个开发者账号

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

2. 创建应用程序:在 Twitter 开发者网站上创建应用程序

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

https://i.stack.imgur.com/gxmnH.png

在此页面上,填写您想要的任何详细信息。对我来说,这并不重要,因为我只是想发出大量阻止请求以摆脱垃圾邮件追随者。关键是您将为自己获取一组用于您的应用程序的唯一键。

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

消费者钥匙

消费者的秘密

访问令牌

访问令牌秘密

有一些关于这些令牌用途的信息 here

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

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

https://i.stack.imgur.com/gEbUQ.png

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

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

如果您想适当地使用此 API,您需要将设置更改为 Read &如果您正在使用 GET 请求执行标准数据检索以外的任何操作,请写入。

https://i.stack.imgur.com/hRHyp.png

选择页面顶部附近的“设置”选项卡。

https://i.stack.imgur.com/pW1tl.png

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

您可以在此处read more about the applications permission model Twitter 使用的。

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

我将上面的代码与一些修改和更改组合到一个 PHP 类中,因此发出您需要的请求非常简单。

这使用 OAuth 和 Twitter 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 documentation 来帮助您选择哪个 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();  

I've put these files on GitHub感谢@lackovic10 和@rivers!我希望有人觉得它有用;我知道我做到了(我将它用于循环中的批量阻塞)。

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


@kaffolder 该页面上的链接:profilepicture.co.uk/caching-api-responses-php 提出了一种简单的方法。您在第一次请求时将 twitter 数据写入文件或数据库(MySQL 或 MongoDB),然后在每个后续请求中检查当前时间与文件所需的时间限制(您可以 name 文件作为时间限制),如果文件存在并且文件名在您想要的时间限制内,则拉取数据而不是执行 API 请求。如果文件存在但超过时间限制,则删除文件然后执行 API 请求。
我不知道如何处理返回的 json 数据。我不想像 echo $twitter ->setGetfield($getfield) ->buildOauth($url, $requestMethod) ->performRequest(); 那样将它回显到屏幕上。道歉,我不知道如何换行!我想做类似 $jsonData = json_decode($twitter);但它不起作用 - 我觉得我错过了一些基本的东西,但一分钱并没有下降......
谢谢,Twitter 的文档杂乱无章,这很有帮助。
要让这个类在 Windows 上运行,有很多先决条件。您需要在 php.ini 文件中加载 cURL 的工作版本,还需要使用 curl.cainfo = path\to\cacert.pemphp.ini 文件中加载 CA 证书。您可以获得 CA 证书 here
@Jimbo我只是注意到一些默认的cURL扩展在Windows中有错误并且需要替换(因此链接到“固定”版本)并且没有加载CA证书,你的类返回一个错误,因为 curl_error ()报告“SSL 证书问题,验证 CA 证书是否正常”。这可以通过关闭 CURLOPT_SSL_VERIFYPEER 来避免,但我想我会包含实际使用 CA 证书的基本说明。只是将其包括在内,可能会为一些人节省几分钟的搜索时间。
G
Geremia

Go to dev.twitter.com and create an application。这将为您提供所需的凭据。这是我最近用 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

感谢您的代码片段,完美地工作。唯一的问题是我似乎无法弄清楚如何设置帖子计数回报。它只返回 20,我想根据 twitter 限制全额支付 200。
您将如何使用这种方法设置 screen_namecount?我尝试将其添加到 $url 变量中,但出现“无法对您进行身份验证”错误。
这段代码很好用!我正在尝试修改它以使用 search/tweets.json api,但我总是得到响应“无法验证你”——有什么想法吗?
这篇文章很有帮助。我的代码似乎没有从 curl_init() 返回。我查看了一些示例,它们看起来非常简单明了,并且与此处的代码完全一样...我需要安装一些特殊的东西吗?
它在 2016 年 10 月 26 日对我有用。输出比我预期的要复杂一些。
P
Peter Mortensen

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

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

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

我不能对此进行足够的投票。在 Twitter 的 API 文档中,这让你眼前一亮,但它从来都不是超级“明显”的。这种方法会与 buildAuthorizationHeader 函数混淆吗?我分别实现了它。
我已经很长时间没有处理这个问题了,所以我不记得了,如果您还没有解决您的问题,我可以在接下来的几天内查看它。
我一直在尝试调整您的解决方案以在 statuses/update.json 上执行 POST,但没有运气,您知道如何实现吗?
@perrohunter 我不知道是否需要对此进行更多研究。如果您在几天内没有找到方法,请给我发消息,我会尽力帮助您。
b
budiDino

就像其他答案中所述,创建一个 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()


很棒的工作@budidino!在 dev.twitter.com/apps 上创建应用程序并用 oauth_access_token、oauth_access_token_secret、consumer_key、consumer_secret 填充您的 x。 *注意*您需要按“创建我的访问令牌”,生成需要几秒钟,所以请稍候。
@budidino dnt 我们需要包含任何库吗?
我填写了密钥,将其添加到我在 WordPress 中的 functions.php 文件中,将 <?php echo returnTweet(); ?> 放入 HTML 文件中,它会输出单词“Array”,仅此而已。
@Desi,结果是推文数组,您应该处理如何显示它们。试试 print_r(returnTweet()) 看看里面有什么。查看显示所有推文的示例:gist.github.com/budidino/9681764#file-stackoverflow-returntweet
如果您只想获取最新的推文,您应该修改 $request 数组并将计数设置为 1。假设您使用 $tweet = returnTweet();那么如果你想显示最新的推文(在这种情况下是唯一的),你可以这样写: echo "latest tweet:" .$tweet[0]["text"];如果您想提取的不仅仅是推文的文本,请务必查看推特返回的结构(例如 $userProfileImageURL = $tweet[0]["user"]["profile_image_url"])。 dev.twitter.com/docs/api/1.1/get/statuses/user_timeline
F
Frewuill

谢谢克里斯!

它在不使用查询参数的情况下对我有用,每当我使用多个参数时,它都会向我显示错误: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:nonce 是一种一次性令牌,应该是加密安全的。 mt_rand() 既太短(32 位)又不是加密 PRNG。从理论上讲,这会使 oauth 令牌变弱,但为了在我的原始示例代码中简单起见,我想使用 PHP 中易于理解的东西。
收到错误 32。无法对您进行身份验证.. 有什么帮助吗???我用过你上面的代码
@frewuill,你是伟大的兄弟,它像魅力一样让我工作,谢谢。
@frewuill 这是最好的答案,它也可以使用参数,我可以确认它甚至可以使用新的 2.0 Twitter API!
K
Kris Reeves

这个问题对我帮助很大,但并没有让我完全理解需要发生的事情。 This blog post 出色地引导我完成了它。

以下是集中在一处的重要信息:

如上所述,您必须签署您的 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);

j
jeffaudio

如果您安装了 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 或他们的 example。您可以使用 pecl install oauth 获取库。


P
Peter Mortensen

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

如果您打算将 GET search/tweets 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,就是这样 :)


我仍然没有运气:/
M
Matthew Rapati

您需要一个 to create an "app" on Twitter(并且您需要一个 Twitter 帐户才能执行此操作)。

然后,您需要use OAuth to make an authorized request to Twitter

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


请为我们这些愚蠢的人解释一下。您提供的见解与文档一样多,甚至更少。您在第 2 步中使用 PHP 的 HttpRequest() 函数吗?亚伯拉罕的 TwitterOAuth PHP - github.com/abraham/twitteroauth - 库也应该这样做,但没有真正提供如何实现它的示例。
@MatthewRapati 页面不见了。
k
kasimir

这是一个简短的,用于从您的时间线中获取指定数量的推文。它与其他示例的功能基本相同,只是代码更少。

只需填写键并根据自己的喜好调整 $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+(以防您的服务器/计算机在某个冷战洞穴中并且您无法升级它)。


G
Geremia

从他们的 signature generator,您可以生成以下形式的 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

M
Mohd Abdul Baquee
$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));

请说明此代码的作用,以便 OP 可以从中学习。
T
Terry Bu

多亏了这个线程,尤其是 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;

?>

r
runs

如果它对任何人有用... 在我的博客中,我实现了以下 PHP 代码,以检索最后的推文,提取它们最相关的数据,然后将它们保存到 MySQL 数据库中。它有效,因为我在我的博客中得到了它。

存储它们的“推文”表:

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。特别是关于数据库
此外,您已将所有密钥和令牌公开,因此如果有人拿走了它并入侵了您的 Twitter 帐户,请不要感到惊讶!

关注公众号,不定期副业成功案例分享
关注公众号

不定期副业成功案例分享

领先一步获取最新的外包任务吗?

立即订阅