it-gundan.com

가장 단순한 PHP Twitter API 버전 1.1을 사용하여 user_timeline을 검색하는 예제

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}]}"

많은 클래스가 있지만, 몇 가지 시도해 본 결과 트위터의 업데이트로 인해 아무 것도 작동하지 않는 것 같습니다. 그 중 일부는 실제로 필요하지 않은 많은 고급 기능을 갖춘 고급 클래스입니다.

PHP로 최근 사용자 상태를 얻는 가장 단순한/가장 짧은 방법은 무엇입니까?

282
fellowworldcitizen

중요 참고 사항 : 2018 년 중반에 Twitter API 토큰을 얻는 프로세스가 훨씬 관료적으로되었습니다. API 토큰 세트를 제공하기 위해 일주일 을 넘겨주었습니다. 1.2 백만 설치 Packagist에, Github에 1.6k의 별이 있으며, 이론적으로 우선 순위가 높아야합니다.

작업을 위해 Twitter API를 사용하여 작업하는 경우이 잠재적으로 긴 대기 시간을 고려해야합니다. 또한 토큰을 검색하는 프로세스가 즉각적이기 때문에 Facebook 또는 Instagram과 같은 다른 소셜 미디어 수단을 고려하고 이러한 옵션을 제공하십시오.


트위터 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 를 방문하여 "Create Application"버튼을 클릭하십시오.

Enter image description here

이 페이지에서 원하는 세부 사항을 입력하십시오. 스팸 추종자를 제거하기 위해 많은 차단 요청을 원했기 때문에 문제가되지 않았습니다. 요점은 당신이 당신의 어플리케이션에 사용할 고유 한 키 세트를 얻는 것입니다.

따라서 응용 프로그램을 만드는 요점은 자신과 트위터에 일련의 키를 제공하는 것입니다. 이것들은:

  • 소비자 키
  • 소비자 비밀
  • 액세스 토큰
  • 액세스 토큰 비밀

이 토큰의 내용에 대해 약간의 정보가 있습니다. here .

3. 액세스 토큰 만들기 : 성공적인 요청을하려면 이것들이 필요합니다

OAuth 몇 개의 토큰을 요청합니다. 따라서 당신을 위해 그것들을 생성해야합니다.

Enter image description here

하단에서 "내 액세스 토큰 만들기"를 클릭하십시오. 그런 다음 바닥으로 다시 스크롤하면 새로 생성 된 키가 생깁니다. API 호출을 위해이 페이지에서 이전에 레이블이 지정된 4 개의 키를 가져 와서 어딘가에 기록하십시오.

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 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에는 전달할 수있는 내용이 나와 있습니다. 위와 같은 "블록"URL을 사용하는 경우 다음 POST 매개 변수를 전달할 수 있습니다.

/** POST fields required by the URL above. See relevant docs as above **/
$postfields = array(
    'screen_name' => 'usernameToBlock', 
    'skip_status' => '1'
);

API로 수행 할 작업을 설정 했으므로 이제 실제 요청을해야합니다.

/** Perform the request and echo the response **/
$Twitter = new TwitterAPIExchange($settings);
echo $Twitter->buildOauth($url, $requestMethod)
             ->setPostfields($postfields)
             ->performRequest();

그리고 POST 요청에 대한 것입니다!

GET 요청의 경우 조금 다릅니다. 예를 들면 다음과 같습니다.

/** Note: Set the GET field BEFORE calling buildOauth(); **/
$url = 'https://api.Twitter.com/1.1/followers/ids.json';
$getfield = '?username=J7mbo';
$requestMethod = 'GET';
$Twitter = new TwitterAPIExchange($settings);
echo $Twitter->setGetfield($getfield)
             ->buildOauth($url, $requestMethod)
             ->performRequest();     

최종 코드 예제 : 내 팔로어 목록에 대한 간단한 GET 요청.

$url = 'https://api.Twitter.com/1.1/followers/list.json';
$getfield = '?username=J7mbo&skip_status=1';
$requestMethod = 'GET';
$Twitter = new TwitterAPIExchange($settings);
echo $Twitter->setGetfield($getfield)
             ->buildOauth($url, $requestMethod)
             ->performRequest();  

이 파일들을 GitHub에 넣었습니다 @ lackovic10 및 @rivers에 대한 크레딧으로! 누군가가 유용하다고 생각하기를 바랍니다. 나는 내가 한 일을 알고있다 (루프에서 대량 차단에 사용했다).

또한 SSL 인증서에 문제가있는 Windows 사용자의 경우 이 게시물 을 참조하십시오. 이 라이브러리는 후드 아래에서 cURL을 사용하므로 cURL 인증서를 설정했는지 확인해야합니다. 구글도 당신의 친구입니다.

810
Jimbo

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

고마워, 크리스!

필자는 하나 이상의 매개 변수를 사용할 때마다 오류를 표시 할 때마다 쿼리에 매개 변수를 사용하지 않고 저에게 도움이되었습니다. 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 인코딩 양식으로 줄이기 전에 매개 변수를 정렬해야합니다.
  • 여러 번 인코딩해야합니다. 예를 들어 매개 변수의 URL 인코딩 값에서 쿼리 문자열을 만든 다음 THAT을 인코딩하고 메서드 유형과 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 또는 example 을 참조하십시오. pecl install oauth를 사용하여 라이브러리를 가져올 수 있습니다.

6
jeffaudio

우선 jimbo와 ( 그의 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_nameq으로 변경하십시오. :)

5
Chanuka Asanka

당신은 to 트위터에 "app"을 만드십시오 (트위터 계정이 필요합니다).

그런 다음 트위터에 승인 된 요청을하기 위해 OAuth를 사용 .

GET status/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))))))));

이것은 익명의 함수와 cURL 라이브러리 대신 file_get_contents를 사용합니다. nonce MD5 hashed의 사용에 유의하십시오. 모두가 time() nonce와 함께하는 것처럼 보입니다. 그러나 OAuth에 관한 웹의 대부분의 예는 암호화 된 문자열을 사용합니다 (예 : http://www.sitepoint.com/understanding-oauth-1/). ). 이것은 나에게도 더 의미가 있습니다.

추가 참고 사항 :익명 기능을 위해 PHP 5.3+가 필요합니다 (서버/컴퓨터가 냉전 동굴에 있고 업그레이드 할 수없는 경우).

0
kasimir