중요 사항 : 2018 년 중반부터 트위터 API 토큰을 얻는 프로세스가 훨씬 관료적으로되었습니다. 그것은을 통해 저를 얻었습니다 주 작업 한 API 토큰 세트를 제공하고,이 이상하면 남자와 여자를위한 오픈 소스 프로젝트입니다 만 1.2 설치 이론적으로 더 높은 우선 순위해야 Github에서에 Packagist에와 1,600 회의 별 .
작업을 위해 twitter API를 사용하는 작업을 수행하는 경우 잠재적으로 매우 긴 대기 시간을 고려해야합니다. 또한 토큰을 검색하는 프로세스가 즉각적이므로 Facebook 또는 Instagram과 같은 다른 소셜 미디어 수단을 고려하고 이러한 옵션을 제공하십시오.
트위터 v1.1 API를 사용 하시겠습니까?
참고 : 이들 파일은 GitHub에 있습니다 .
버전 1.0 은 곧 더 이상 사용되지 않으며 승인되지 않은 요청은 허용되지 않습니다. 그래서 여기에 당신의 삶을 편하게 해주는 PHP 클래스와 함께 그 일을 도와주는 게시물이 있습니다.
1. 개발자 계정 만들기 : Twitter 에서 개발자 계정 을 설정하십시오 .
공식 Twitter 개발자 사이트를 방문하여 개발자 계정을 등록해야합니다. 이것은 v1.1 API를 요청 하는 무료 단계입니다.
2. 애플리케이션 작성 : Twitter 개발자 사이트에서 애플리케이션 작성
뭐? 인증되지 않은 요청을 할 수 있다고 생각 했습니까? Twitter의 v1.1 API에는 해당되지 않습니다. http://dev.twitter.com/apps 를 방문 하여 "응용 프로그램 만들기"버튼을 클릭 해야 합니다.
이 페이지에서 원하는 세부 사항을 입력하십시오. 스팸 추종자를 제거하기 위해 많은 차단 요청을 원했기 때문에 문제가되지 않았습니다. 요점은 응용 프로그램에 사용할 고유 키 세트 를 얻는 것 입니다.
따라서 응용 프로그램을 만드는 요점은 자신과 트위터에 일련의 키를 제공하는 것입니다. 이것들은:
- 소비자 키
- 소비자 비밀
- 액세스 토큰
- 액세스 토큰 비밀
여기 에 이러한 토큰에 대한 정보가 약간 있습니다 .
3. 액세스 토큰 생성 : 성공적인 요청을 위해서는이 토큰 이 필요합니다
OAuth 는 몇 개의 토큰을 요청합니다. 따라서 당신을 위해 그것들을 생성해야합니다.
하단에서 "내 액세스 토큰 만들기"를 클릭하십시오. 그런 다음 바닥으로 다시 스크롤하면 새로 생성 된 키가 생깁니다. API 호출을 위해이 페이지에서 이전에 레이블이 지정된 4 개의 키를 가져 와서 어딘가에 기록하십시오.
4. 액세스 수준 변경 : 읽기 전용을 원하지 않습니까?
이 API를 적절하게 사용하려면 GET 요청을 사용하여 표준 데이터 검색 이외의 작업을 수행하는 경우 설정을 읽기 및 쓰기로 변경해야 합니다.
페이지 상단 근처의 "설정"탭을 선택하십시오.
응용 프로그램에 읽기 / 쓰기 권한을 부여하고 맨 아래에서 "업데이트"를 누르십시오.
당신은 할 수 있는 응용 프로그램 권한 모델에 대한 자세한 내용을 트위터 여기에 사용.
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에는 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에는 전달할 수있는 내용이 나와 있습니다. 위와 같은 "blocks"URL을 사용하는 경우 다음 POST 매개 변수를 전달할 수 있습니다.
/** POST fields required by the URL above. See relevant docs as above **/
$postfields = array(
'screen_name' => 'usernameToBlock',
'skip_status' => '1'
);
API로 수행하려는 작업을 설정 했으므로 이제 실제 요청을해야합니다.
/** Perform the request and echo the response **/
$twitter = new TwitterAPIExchange($settings);
echo $twitter->buildOauth($url, $requestMethod)
->setPostfields($postfields)
->performRequest();
그리고 POST 요청의 경우 끝입니다!
A에 대한 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 에 넣었습니다! 누군가가 유용하다고 생각합니다. 나는 내가 한 일을 알고있다 (루프에서 대량 차단에 사용했다).
또한 SSL 인증서에 문제가있는 Windows 사용자는 이 게시물을 참조하십시오 . 이 라이브러리는 후드 아래에서 cURL을 사용하므로 cURL 인증서가 설정되어 있는지 확인해야합니다. 구글도 친구입니다.