it-swarm.cn

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

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

282
fellowworldcitizen

重要说明: 截至2018年中期,获取Twitter API令牌的过程变得更加官僚主义。它让我超过 一个工作周 提供一组API令牌,这是一个开源项目,适用于包含超过1.2百万安装的所有人和女孩Github上的1.6k星,理论上应该是更高的优先级。

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


那么你想使用Twitter v1.1 API吗?

注意:这些文件位于GitHub

版本1.0 将很快被弃用 并且不允许未经授权的请求。所以,这里有一篇帖子可以帮助你做到这一点,还有一个PHP类让你的生活更轻松。

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

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

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

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

Enter image description here

在此页面上,填写您想要的任何详细信息。对我来说,这没关系,因为我只是想加载一些块请求来摆脱垃圾邮件粉丝。重点是你将获得一组唯一键用于你的应用程序。

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

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

关于这些令牌的内容,有一些信息 here

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

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

Enter image description here

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

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

如果您想要正确使用此API,则除非使用 GET 请求执行标准数据检索以外的任何操作,否则您需要将设置更改为“读取和写入”。

Enter image description here

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

Enter image description here

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

您可以 阅读有关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文档来帮助您选择哪个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都说明了可以传递给它的内容。如果我们使用上面的“块”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();

对于POSTrequest,就是这样!

对于 _ get _ request,它有点不同。这是一个例子:

/** 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证书问题的人,请查看 this post 。此库使用cURL,因此您需要确保可能已设置cURL证书。谷歌也是你的朋友。

798
Jimbo

访问dev.Twitter.com并创建一个应用程序 。这将为您提供所需的凭据。这是我最近用 _ php _cURL 编写的实现。

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

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

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

18
budidino

谢谢Kris!

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

希望它能解决我遇到同样问题的人。

16
Frewuill

这个问题帮助了我很多,但没有让我一路了解需要发生的事情。 这篇博客文章 给我带来了惊人的工作。

以下是一个重要的位:

  • 如上所述,您必须签署您的1.1 API请求。如果您正在执行诸如获取公共状态之类的操作,则需要应用程序密钥而不是用户密钥。指向所需页面的完整链接: https://dev.Twitter.com/apps
  • 您必须一起散列所有参数,包括oauth和get参数(或POST参数)。
  • 您必须先将参数排序,然后再将其缩小为经过哈希处理的网址编码格式。
  • 您必须多次对某些内容进行编码 - 例如,您从参数'url-encoded values创建一个查询字符串,然后您对该方法类型和网址进行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);
9
Kris Reeves

如果您安装了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来获取库。

6
jeffaudio

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

如果您打算使用 GET搜索/推文API 与“Twitter-api-php”PHP library(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,就是这样:)

5
Chanuka Asanka

你需要一个 在Twitter上创建一个“应用程序” (你需要一个Twitter帐户才能这样做)。

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

您可以使用 GET状态/ user_timeline resource来获取最近的推文列表。

2
Matthew Rapati

以下是从您的时间轴中获取指定数量的推文的简短说明。它基本上与其他示例完全相同,只是代码较少。

只需填写按键并根据自己的喜好调整$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() nonce,但是,网络上关于OAuth的大多数示例都使用某种加密字符串(如下所示: http://www.sitepoint.com/understanding-oauth-1/ )。这对我来说也更有意义。

进一步说明: 你需要PHP 5.3+用于匿名函数(如果你的服务器/计算机处于某个冷战洞穴而你无法升级它)。

0
kasimir