Прерывистое плохое приложение Facebook Access_token
-
27-10-2019 - |
Вопрос
Я создаю тестовые пользователи в Facebook для моего приложения. Иногда это работает. Когда это не так, ошибка возникает на этом вызове:
function getTestAccounts($fb, $a) {
$s = urlencode($a);
**$accounts = $fb->api("/{$fb->getAppId()}/accounts/test-users?access_token=$s");**
if( isset($accounts['data']) )
return $accounts;
else
return null;
}
Ошибка:
Unceant oauthexception: (#15) Этот метод должен быть вызван с помощью приложения Access_token.
Ранее я получил токен с этой функцией:
function getAppAccessToken($fb) {
$access_token_url = "https://graph.facebook.com/oauth/access_token";
$parameters = "grant_type=client_credentials&client_id=" . $fb->getAppId() . "&client_secret=" . $fb->getApiSecret() . "&junk=1";
return file_get_contents($access_token_url . "?" . $parameters);
}
Когда я выключаю оскорбительный токен, он выглядит примерно так и не меняется (должно ли это?)
access_token = 229234510434203 | tk2udogcpthcbedivhripksg8wk
Я пытался очистить куки. Это, казалось, сработало, но могло бы быть случайным с чем -то другим, потому что сейчас это не так.
Я предполагаю, что токен доступа вернулся из изменений FB, но он всегда возвращается одинаково.
Решение 2
Я совершил ошибку Гринхора. Что я не заметил, так это то, что эта проблема возникла только после того, как я открыл другую вкладку браузера и вошел в Facebook в качестве меня или для тестового пользователя. Новая сессия Facebook мешала API.
Я полагаю, что API использует токен доступа зарегистрированного пользователя, а не то, что передается в запросе. Что -то вроде очевидно, как только вы это поймете!
Надеюсь, это поможет следующему человеку :-)
Другие советы
Отметка
Для пользовательского токена доступа я использую ниже, где номер является моим идентификатором приложения. "Используется с PHP-SDK"
$access_token = $_SESSION['fb_135669679827333_access_token'];
Для токена доступа к приложению я использую curl
$app_access_token = GetCH();
function GetCH(){
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, "https://graph.facebook.com/oauth/access_token?client_id=YOUR_APP_ID&client_secret=YOUR_APP_SECRET&grant_type=client_credentials");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_USERAGENT, $_SERVER['HTTP_USER_AGENT']);
if(substr($url,0,8)=='https://'){
// The following ensures SSL always works. A little detail:
// SSL does two things at once:
// 1. it encrypts communication
// 2. it ensures the target party is who it claims to be.
// In short, if the following code is allowed, CURL won't check if the
// certificate is known and valid, however, it still encrypts communication.
curl_setopt($ch,CURLOPT_HTTPAUTH,CURLAUTH_ANY);
curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false);
}
$sendCH = curl_exec($ch);
curl_close($ch);
return $sendCH;
};
Позвольте мне знать, если это помогает.