2013-04-12 3 views
5

Основываясь на 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 ниже в браузере

https://graph.facebook.com/oauth/access_token?client_id=App_Id&redirect_uri=http://apps.facebook.com/poemsoflove&client_secret=App_Secret&code=AQCn41Svv5DbWrnFY0Wf.....YbNm_yz2rE#_&display=popup

вы получите следующие реагировать который является новым маркером доступа в течение 60 дней

access_token=<Extended_Access_Token>&expires=5180130 

скопировать и вставить строку после access_token = скрипту на вашем сервере, который публикует новые сообщения на вашей странице

+1

Это означает, что старый маркер доступа уже истек. Не могли бы вы повторить одно и то же с новым краткосрочным токеном доступа –

+0

спасибо, что я сделал это с новым краткосрочным токеном доступа – stefanosn

+3

Вы только что указали маркер доступа миру, будьте осторожны. Любой может злоупотреблять им. –

ответ

0
  1. Создать приложение Facebook Developer Page

После с PHP может получить живой Toke ACCESS

$app_id = '{Application Id}'; 
$app_secret = '{Application Secret}'; 
$access_token = "https://graph.facebook.com/oauth/access_token?client_id=$app_id&client_secret=$app_secret&grant_type=client_credentials"; 
$access_token = file_get_contents($access_token); // returns 'accesstoken=APP_TOKEN|APP_SECRET' 
$access_token = str_replace('access_token=', '', $access_token); 
0
$app_id = 'APP_ID'; 
$app_secret = 'APP_SECRET'; 
$access_token_url = "https://graph.facebook.com/oauth/access_token?client_id=$app_id&client_secret=$app_secret&grant_type=client_credentials"; 
$access_token_data = file_get_contents($access_token_url); 
$access_token_arr = json_decode($access_token_data); 
$access_token = $access_token_arr->access_token; 
+1

Пожалуйста, не просто отправляйте код в качестве ответа. Пожалуйста, объясните свою логику. –

Смежные вопросы