301

2013 年 6 月 11 日に 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で最近のユーザーステータスを取得する最も簡単/最短の方法は何ですか?

4

14 に答える 14

832

重要な注意: 2018 年半ばの時点で、Twitter API トークンを取得するプロセスはより官僚的になりました。API トークンのセットが提供されるまでに1 週​​間以上かかりました。これは、Packagist で120 万回以上のインストールがあり、Github で 1.6k スターがあり、理論的には優先度が高いはずの皆さんのためのオープンソース プロジェクトです。.

仕事で twitter API を使用する場合は、この非常に長い待ち時間を考慮に入れる必要があります。また、Facebook や Instagram などの他のソーシャル メディアの手段を検討し、これらのオプションを提供してください。それらのトークンを取得するプロセスは瞬時に完了します。


Twitter v1.1 API を使用しますか?

注: これらのファイルは GitHub にあります

バージョン 1.0は間もなく廃止され、承認されていないリクエストは許可されなくなります。そこで、これを行うのに役立つ投稿と、作業を楽にする PHP クラスを紹介します。

1. 開発者アカウントを作成する: Twitter で開発者アカウントを設定します。

公式の Twitter 開発者サイトにアクセスして、開発者アカウントに登録する必要があります。これは、v1.1 API のリクエストを作成するために必要な無料のステップです。

2. アプリケーションの作成: Twitter 開発者サイトでアプリケーションを作成します。

何?認証されていないリクエストを行うことができると思いましたか? Twitter の v1.1 API にはありません。http://dev.twitter.com/appsにアクセスして、[Create Application] ボタンをクリックする必要があります。

ここに画像の説明を入力してください

このページで、必要な詳細を入力します。私にとっては、それは問題ではありませんでした。なぜなら、スパム フォロワーを取り除くために大量のブロック リクエストを作成したかったからです。重要なのは、アプリケーションで使用する一意のキーのセットを取得することです。

したがって、アプリケーションを作成するポイントは、自分自身 (および Twitter) に一連のキーを与えることです。これらは:

  • コンシューマ キー
  • 消費者の秘密
  • アクセストークン
  • アクセス トークン シークレット

これらのトークンの目的に関する情報が少しあります

3. アクセス トークンの作成: リクエストを成功させるには、これらが必要になります。

OAuthはいくつかのトークンを要求します。したがって、それらを生成する必要があります。

ここに画像の説明を入力してください

下部にある「アクセス トークンを作成する」をクリックします。次に、もう一度一番下までスクロールすると、新しく生成されたキーがいくつか表示されます。API 呼び出しのために、このページから以前にラベル付けされた 4 つのキーを取得する必要があるため、それらをどこかにメモしておいてください。

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 には、URL と要求タイプ (POST または GET) を選択するのに役立つAPI ドキュメントがあります。

/** 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();

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

これらのファイルは、@lackovic10 と @rivers の功績により GitHubに掲載しました。誰かが役に立つことを願っています。私がしたことは知っています(ループでの一括ブロックに使用しました)。

また、Windows で SSL 証明書に問題がある場合は、この投稿を参照してください。このライブラリは内部で cURL を使用するため、cURL 証明書が設定されていることを確認する必要があります。グーグルもあなたの友達です。

于 2013-03-09T19:02:11.867 に答える
140

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
于 2012-10-17T17:26:39.763 に答える
62

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
           );
于 2012-12-22T23:18:23.663 に答える
21

他の回答で述べたように、Twitter アプリを作成してトークン、キー、シークレットを取得します。次のコードを使用すると、リクエスト パラメータを 1 か所から変更して、タイプミスや同様のエラーを回避できます (関数$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()

于 2013-04-23T12:52:02.330 に答える
17

クリスありがとう!

クエリにパラメーターを使用しなくても機能しましたが、複数のパラメーターを使用すると、エラーが表示されました: 32 Could not authenticate you.

私にとっての問題は、アンパサンドのエンコーディングにありました。したがって、次の行のコードで

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

以下に次の行を追加しました。

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

そして、screen_name や count などの 2 つ以上のパラメーターを使用して機能しました。

コード全体は次のようになります。

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

私が抱えていたのと同じ問題を抱えている人に役立つことを願っています。

于 2013-04-05T17:50:47.850 に答える
9

この質問は私を大いに助けましたが、何が起こる必要があるかを理解するのに私を完全に理解させることはできませんでした。このブログ投稿は、私にそれを説明するという素晴らしい仕事をしました。

重要な部分をすべて1か所にまとめました。

  • 上で指摘したように、1.1APIリクエストに署名する必要があります。公開ステータスの取得などを行う場合は、ユーザーキーではなくアプリケーションキーが必要になります。必要なページへの完全なリンクは次のとおりです: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);
于 2013-03-14T01:23:58.763 に答える
5

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ライブラリを取得するために使用できます。

于 2013-03-18T18:19:20.667 に答える
5

まず最初に、jimbo と (彼の投稿/ twitter-api-php シンプルなライブラリ) に感謝したいと思います。

"twitter-api-php" PHP ライブラリ (TwitterAPIExchange.php)でGET 検索/ツイート APIを使用する場合:

まず、「POST リクエストを実行し、レスポンスをエコーする」コード領域にコメントするだけです。

「GET リクエストを実行してレスポンスをエコーする」コードを使用し、レスポンスをエコーし​​て、次の 2 行を変更するだけです。

$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それだけです:)

于 2013-06-17T06:04:41.413 に答える
2

Twitter で「アプリ」を作成するには が必要です (これを行うには Twitter アカウントが必要です)。

次に、 OAuth を使用して、承認済みのリクエストを Twitter に送信する必要があります。

GET statuses/user_timelineリソースを使用して、最近のツイートのリストを取得できます。

于 2012-10-16T18:48:52.447 に答える
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 ハッシュされた nonce の使用に注意してください。誰もがtime()nonce に従っているように見えますが、OAuth に関する Web 上のほとんどの例では、ある種の暗号化された文字列が使用されています ( http://www.sitepoint.com/understanding-oauth-1/など)。これは私にとっても理にかなっています。

さらに注意:匿名関数にはPHP 5.3+が必要です(サーバー/コンピューターが冷戦の洞窟にあり、アップグレードできない場合)。

于 2015-01-13T13:51:16.623 に答える
-2

誰にとっても役立つ場合...私のブログでは、最後のつぶやきを取得し、最も関連性の高いデータを抽出して、MySQL データベースに保存するために、次の PHP コードを実装しました。ブログに書いてあるので大丈夫です。

それらを保存する「つぶやき」テーブル:

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;
}
于 2015-12-31T14:38:49.097 に答える
-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));
于 2014-06-23T07:26:50.023 に答える