Вопрос

Я создаю тестовые пользователи в 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;
};

Позвольте мне знать, если это помогает.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top