Прочитать пост на Facebook и срок действия токена - PullRequest
0 голосов
/ 05 февраля 2012

Мне нужно прочитать с сервера поток конкретной фан-страницы. Я пытался прочитать график API https://graph.facebook.com//feed?access_token=&limit=100 и это работает. Что мне нужно, так это понять, истекает ли токен и как его обновлять программно. Теперь я генерирую свой токен через приложение http://developers.facebook.com/tools/explorer/. Не могли бы вы мне помочь? Я использую PHP SDK Спасибо, а.

1 Ответ

1 голос
/ 05 февраля 2012

Вы можете прочитать страницу на Facebook, используя приведенные ниже коды, а также получить указанные поля

https://graph.facebook.com/$page_id/?fields=link,etc&access_token=page_access_token

или

$response = $fb->api($page_id .  '/?fields=link,etc&'. $access_token, 'GET')

Ниже приведено решение для четырех сценариев

1. Срок действия токена истекает после истечения времени (по умолчанию 2 часа).
2. Пользователь изменяет свой пароль, который делает недействительным токен доступа.
3. Пользовательдеавторизует ваше приложение.
4. Пользователь выходит из Facebook.

Чтобы обеспечить максимальное удобство для ваших пользователей, ваше приложение должно быть готово к обнаружению ошибок в указанных выше сценариях.В следующем PHP-коде показано, как обрабатывать эти ошибки и получать новый токен доступа.

Когда вы перенаправляете пользователя в диалоговое окно авторизации, у пользователя не запрашиваются разрешения, если пользователь уже авторизовал ваше приложение.Facebook вернет вам действительный токен доступа без диалога с пользователем.Однако, если пользователь отменил авторизацию вашего приложения, ему необходимо будет повторно авторизовать ваше приложение, чтобы вы получили access_token.

<?php
$app_id = "YOUR_APP_ID";
$app_secret = "YOUR_APP_SECRET"; 
$my_url = "YOUR_POST_LOGIN_URL";

// known valid access token stored in a database 
$access_token = "YOUR_STORED_ACCESS_TOKEN";

$code = $_REQUEST["code"];

// If we get a code, it means that we have re-authed the user 
//and can get a valid access_token. 
if (isset($code)) {
$token_url="https://graph.facebook.com/oauth/access_token?client_id="
  . $app_id . "&redirect_uri=" . urlencode($my_url) 
  . "&client_secret=" . $app_secret 
  . "&code=" . $code . "&display=popup";
$response = file_get_contents($token_url);
$params = null;
parse_str($response, $params);
$access_token = $params['access_token'];
}


// Attempt to query the graph:
$graph_url = "https://graph.facebook.com/me?"
. "access_token=" . $access_token;
$response = curl_get_file_contents($graph_url);
$decoded_response = json_decode($response);

//Check for errors 
if ($decoded_response->error) {
// check to see if this is an oAuth error:
if ($decoded_response->error->type== "OAuthException") {
  // Retrieving a valid access token. 
  $dialog_url= "https://www.facebook.com/dialog/oauth?"
    . "client_id=" . $app_id 
    . "&redirect_uri=" . urlencode($my_url);
  echo("<script> top.location.href='" . $dialog_url 
  . "'</script>");
}
else {
  echo "other error has happened";
}
} 
else {
// success
echo("success" . $decoded_response->name);
echo($access_token);
}

// note this wrapper function exists in order to circumvent PHP’s 
//strict obeying of HTTP error codes.  In this case, Facebook 
//returns error code 400 which PHP obeys and wipes out 
//the response.
function curl_get_file_contents($URL) {
$c = curl_init();
curl_setopt($c, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($c, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($c, CURLOPT_URL, $URL);
$contents = curl_exec($c);
$err  = curl_getinfo($c,CURLINFO_HTTP_CODE);
curl_close($c);
if ($contents) return $contents;
else return FALSE;
}
?>

для получения более подробной информации вы можете посетить эту ссылку
Спасибо

...