Twitter APIバージョン1.1でuser_timelineを取得する最も単純なPHPの例


292

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


97
私はこれに対する答えを殺すでしょう。彼らの文書は恐ろしく悪いです。
RCNeil 2012年

私はTwitter APIを初めて使用し、少し苦労しています。私は非推奨のコードを使用していることに気づきました。
アンソニー


@MarkありがとうMark !! 簡単でした!! 最初はそれでうまくいきませんでした。WAMPを実行しています。:私はこのスレッドに応じて私のApacheのディレクトリに私のphp.iniに変更を加える必要があった stackoverflow.com/questions/5444249/...
Adlin玲

1
:私はちょうどCURLやその他の余分なライブラリなしでソリューションを書き留めたstackoverflow.com/questions/17049821/...
Rauli Rajande

回答:


820

重要な注意: 2018年半ば以降、Twitter APIトークンを取得するプロセスは、より官僚的なものになりました。これは、上で私を撮影した1週労働 APIトークンのセットを提供するために、これはオーバーと君たちと女の子のためのオープンソースプロジェクトである120万のインストールが理論的に高い優先順位でなければなりませんPackagist上との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リクエストを使用して標準のデータ取得以外のことを行う場合は、設定を読み取りと書き込みに変更する必要があります。

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

ページの上部にある[設定]タブを選択します。

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

アプリケーションに読み取り/書き込みアクセス権を付与し、下部にある「更新」をクリックします。

あなたはできるアプリケーションのアクセス許可モデルの詳細を読むツイッターをここで使用していること。


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証明書が設定されていることを確認する必要があります。Googleもあなたの友達です。


4
そのページ上のリンク@kaffolder:profilepicture.co.uk/caching-api-responses-phpはそれを行うための簡単な方法を示唆しています。あなたは、あなたがファイルに必要制限時間(あなたは可能性に対して、現在の時刻を確認し、すべての後続の要求、その後、最初の要求に応じて、ファイル、またはデータベース(MySQLやMongoDBの)に自分のTwitterデータを書き込む名前時間制限などのファイルを)、およびファイルが存在し、ファイル名が必要な制限時間内にある場合は、APIリクエストを実行する代わりにデータをプルします。ファイルは存在するが制限時間が経過した場合は、ファイルを削除してからAPIリクエストを実行します。
Jimbo

7
返されたjsonデータの処理方法がわかりません。echo $ twitter-> setGetfield($ getfield)-> buildOauth($ url、$ requestMethod)-> performRequest();のように、画面に単にエコーしたくありません。謝罪、改行の仕方がわからない!$ jsonData = json_decode($ twitter);のようなことをしたいです。しかし、それは動作しません-私は基本的な何かが欠けているように感じますが、ペニーはうまくいきません...
アシュリー

67
ありがとう、Twitterのドキュメントはまとまりのない混乱であり、これは非常に役立ちました。
ジョーレン2013

7
このクラスをWindowsで動作させるためには、いくつかの前提条件があります。ファイルにcURLの有効なバージョンをロードし、php.iniさらにphp.iniを使用してファイルにCA証明書をロードする必要がありますcurl.cainfo = path\to\cacert.pemここで CA証明書を取得できます
ジェイクZ

4
@Jimbo私は、デフォルトのcURL拡張機能の一部がWindowsでバグがあり、置き換えが必要であること(したがって「修正済み」バージョンへのリンク)と、CA証明書をロードせずに、curl_error()としてクラスがfalseを返すことに注意しました「SSL証明書の問題です。CA証明書に問題がないことを確認してください」と報告します。これはCURLOPT_SSL_VERIFYPEERをオフにすることで回避できますが、実際にCA証明書を使用するための基本的な手順を含めようと思いました。これを含めるだけで、一部の人々の数分の検索を節約できる可能性があります。
ジェイク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を返すだけであり、私はツイッターの制限ごとに200である全額にしたいです。
Flatlyn

23
どのように設定しますscreen_nameと、countこのアプローチには?$url変数に追加してみましたが、「認証できませんでした」というエラーが表示されました。
Javier Villanueva

1
このコードはうまくいきます!search / tweets.json apiを使用するように変更しようとしていますが、常に「認証できませんでした」という応答を受け取っています。
Chris

1
この投稿は非常に役に立ちました。curl_init()しかし、私のコードは元に戻らないようです。私はいくつかの例を見てきましたが、それらは非常にシンプルでわかりやすく、このコードとまったく同じように見えます...特別なものをインストールする必要がありますか?
jessicaraygun 2013年

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

私は長い間これを扱っていなかったので、覚えていません。まだ問題を解決していない場合は、翌日中に調査することができます。
missovic10 2014年

私はあなたのソリューションを運良くステータス/update.jsonでPOSTを実行するように適応させようとしてきましたが、これがどのようにして達成できるかについて何か考えがありますか?
perrohunter 14

1
@perrohunter私はこれについてもっと検討する必要があるとは思いません。数日以内に方法が見つからない場合は、私にメッセージを送ってください。私がお手伝いします。
missovic10 2014

18

他の回答で述べたように、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()


1
素晴らしい仕事@budidino!dev.twitter.com/appsでアプリケーションを作成し、xにoauth_access_token、oauth_access_token_secret、consumer_key、c​​onsumer_secretを入力しました。*注意*「Create my access token」を押す必要があり、生成されるまで数秒かかるので、お待ちください。
Theo

@budidino dntライブラリを含める必要がありますか?
anam 2014年

キーを入力し、functions.phpWordPressのファイルにこれを追加<?php echo returnTweet(); ?>し、HTMLファイルを挿入すると、「配列」という単語のみが出力されます。
J82、

@Desi、結果はつぶやきの配列です。それぞれのつぶやきをどのように表示するかを処理する必要があります。何が入っているかを確認するためだけにprint_r(returnTweet())を試してください。すべてのツイートを表示するこの例を確認してください:gist.github.com/budidino/9681764#file-stackoverflow-returntweet
budidino

1
最新のツイートだけをフェッチしたい場合は、$ request配列を変更して、countを1に設定する必要があります。$ tweet = returnTweet();を使用するとします。次に、最新のツイート(この場合は1つだけ)を表示する場合は、次のように記述します。echo "late Tweet:"。$ tweet [0] ["text"]; ツイートのテキストだけではない場合は、返されるTwitterの構造を確認してください(例$ userProfileImageURL = $ tweet [0] ["user"] ["profile_image_url"])。dev.twitter.com/docs/api/1.1/get/statuses/user_timeline
budidino

16

クリス、ありがとう!

クエリにパラメーターを使用せずに機能しましたが、複数のパラメーターを使用した場合は常にエラーが表示されました:32認証できませんでした。

私にとっての問題は、アンパサンドエンコーディングでした。だからあなたのコードでは次の行です

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

それが私が持っていた同じ問題を持つ誰かを助けることを願っています。


おかげで、あなたのコードの改善はうまくいきます!再質問:「//より強力なノンスが推奨されます」。それは何でしょうか?時間()?
セバスチャン

ご指摘いただきありがとうございます。セバスチャン:nonceは使い捨てのトークンで、暗号的に安全でなければなりません。mt_rand()は短すぎ(32ビット)、暗号化PRNGではありません。理論的には、これはoauthトークンを弱くしますが、元のサンプルコードを単純化するために、PHPで手元にあり、すぐに理解できるものを使用したいと考えました。
クリスリーブス

エラー32を受信しました。認証できませんでした。何か助けてください??? 上記のコードを使用しました
saadk '27 / 07/27

@frewuill、あなたは素晴らしい仲間です、それは私を魅力のように働いています、ありがとう。
ビジェイ2017年

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

詳細については、ドキュメントまたはその例をご覧ください。pecl install oauthライブラリを取得するために使用できます。


5

まず第一に、私はjimboと(彼の投稿 / twitter-api-php simple library)に感謝したいと思いました。

「twitter-api-php」PHPライブラリー(TwitterAPIExchange.php)でGET search / tweets 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_nameするにはq、それはそれだ:)


私はまだ運がありません:/
Ricardo

2

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

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

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


4
私たち愚かな人々のために、説明してください。ドキュメントよりも少なくても、多くの洞察を提供します。HttpRequest()ステップ2でPHPの関数を使用していますか?AbrahamのTwitterOAuth PHP-github.com/abraham/twitteroauth-ライブラリもありますが、これも実行するはずですが、実装方法の例は実際には提供されていません。
RCNeil 2012年

2
github.com/abraham/twitteroauth/blob/master/test.phpには多くの例があるようです!
Matthew Rapati、

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に関するWeb上のほとんどの例では、ある種の暗号化された文字列を使用しています(このような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データを取得する方法を提供したかっただけです。コードの「// 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;

?>

-2

誰にとっても便利な場合...私のブログでは、最新のツイートを取得し、最も関連性の高いデータを抽出してMySQLデータベースに保存するために、次のPHPコードを実装しました。私は私のブログでそれを得たのでそれは機能します。

それらを格納する "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;
}

「ブログで手に入れたからうまくいく」は私のお気に入りの1つです。あなたの投稿は実際の質問には答えません。また、使用しているphpコードの品質が悪い。ここでphptherightway.comを少し読んでください。特にDBについて
Maciej Paprocki

また、すべてのキーとトークンを公開したので、誰かがあなたのTwitterアカウントをハッキングしても驚かないでください!
garrettlynch
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.