Основываясь на facebook instructions (Scenario 4) я использую следующий URLмаркер доступа facebook истек
https://graph.facebook.com/oauth/access_token?client_id=APP_ID&client_secret=CLIENT_SECRET& grant_type=fb_exchange_token&fb_exchange_token=OLD_ACCESS_TOKEN
, чтобы получить новый маркер доступа, но я получаю следующее:
{ "ошибка": {сообщение » »:« Ошибка проверки токена доступа: сеанс истек в unix-времени 1365257820. Текущее время unix равно 1365759029. », « type »:« OAuthException », « код »: 190, « error_subcode »: 463}}
не работает. Любая помощь оценивается.
EDIT: Got it! Работает как этот
если маркер доступа истекает срок выполнения ниже PHP скрипт первым в браузере после сохранения его на сервере
<?php
$app_id = "your app id";
$app_secret = "your app secret";
$my_url = "http://apps.facebook.com/your_app_name";
// known valid access token stored in a database
$access_token = "your old 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_URL, $URL);
$contents = curl_exec($c);
$err = curl_getinfo($c,CURLINFO_HTTP_CODE);
curl_close($c);
if ($contents) return $contents;
else return FALSE;
}
?>
выше сценарий даст вам URL, как показано ниже в браузере
https://graph.facebook.com/oauth/access_token?code= ...
затем получить строку (должно быть что-то вроде этого: AQCn41Svv5DbWrnFY0Wf ..... YbNm_yz2rE # _) после кода = и вставить его на код = URL ниже и запустить URL ниже в браузере
вы получите следующие реагировать который является новым маркером доступа в течение 60 дней
access_token=<Extended_Access_Token>&expires=5180130
скопировать и вставить строку после access_token = скрипту на вашем сервере, который публикует новые сообщения на вашей странице
Это означает, что старый маркер доступа уже истек. Не могли бы вы повторить одно и то же с новым краткосрочным токеном доступа –
спасибо, что я сделал это с новым краткосрочным токеном доступа – stefanosn
Вы только что указали маркер доступа миру, будьте осторожны. Любой может злоупотреблять им. –