Я использую код, основанный на приложении для проверки подлинности Twitter-приложений Jon Hurlock, уже более года без проблем, и около 2 дней назад он начал возвращать эту ошибку при попытке создания маркера-носителя:
Недействительный или истекший токен, код: 89
Мой код слегка изменен, чтобы заставить его проверять SSL, поскольку страница не находится в домене с поддержкой SSL. У меня есть завиток в последнем файле cacert.pem.
Это уровень приложения oauth, а не индивидуальное лицо. Поэтому каждый раз, когда выполняется вызов, я генерирую токен-носитель, вызываю вызов API, а затем недействителен токен-носитель. Вы можете увидеть его оригинальный код здесь (я вытащил последнюю версию для той части, которую я использую): https://github.com/jonhurlock/Twitter-Application-Only-Authentication-OAuth-PHP/blob/master/Oauth.php
Это код, используемый для получения токена-носителя. Примечание. Мне нужно только указать ключ и секрет приложения, нет ни одного пользователя, и пользователь никогда не должен разрешать приложение и не аутентифицировать его:
// Step 1 // step 1.1 - url encode the consumer_key and consumer_secret in accordance with RFC 1738 $encoded_consumer_key = urlencode(CONSUMER_KEY); $encoded_consumer_secret = urlencode(CONSUMER_SECRET); // step 1.2 - concatinate encoded consumer, a colon character and the encoded consumer secret $bearer_token = $encoded_consumer_key.':'.$encoded_consumer_secret; // step 1.3 - base64-encode bearer token $base64_encoded_bearer_token = base64_encode($bearer_token); // step 2 $url = "https://api.twitter.com/oauth2/token"; // url to send data to for authentication $headers = array( "POST /oauth2/token HTTP/1.1", "Host: api.twitter.com", "User-Agent: Twitter App-Only Search", "Authorization: Basic ".$base64_encoded_bearer_token, "Content-Type: application/x-www-form-urlencoded;charset=UTF-8" ); $ch = curl_init(); // setup a curl curl_setopt($ch, CURLOPT_URL,$url); // set url to send to curl_setopt($ch, CURLOPT_HTTPHEADER, $headers); // set custom headers curl_setopt($ch, CURLOPT_POST, 1); // send as post curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); // return output curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, True); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2); curl_setopt($ch, CURLOPT_CAINFO, "/directory/path/cacert2014.pem"); curl_setopt($ch, CURLOPT_POSTFIELDS, "grant_type=client_credentials"); $header = curl_setopt($ch, CURLOPT_HEADER, 1); // send custom headers $httpcode = curl_getinfo($ch, CURLINFO_HTTP_CODE); $retrievedhtml = curl_exec ($ch); // execute the curl curl_close($ch); // close the curl