1

有効期間の長いアクセス トークンを更新する必要があります。Renew longlive access token server side topicを読み 、次のようにコードを書きました。

<?php

$code = $_REQUEST["code"];

if(empty($code)) {

  $dialog_url = "https://www.facebook.com/dialog/oauth?"
    . "client_id=$app_id"
    . "&redirect_uri=$my_url"
    . "&scope=..."
    ;

  echo("<script> top.location.href='" . $dialog_url . "'</script>");
}
else
{
  $response = file_get_contents("https://graph.facebook.com/oauth/access_token?"
    . "client_id=$app_id"
    . "&redirect_uri=$my_url"
    . "&client_secret=$app_secret"
    . "&code=$code"
    );

  $params = null;
  parse_str($response, $params);
  $access_token=$params['access_token'];

  $response = file_get_contents("https://graph.facebook.com/oauth/access_token?"
    . "client_id=$app_id"
    . "&client_secret=$app_secret"
    . "&redirect_uri=$my_url"
    . "&grant_type=fb_exchange_token"
    . "&fb_exchange_token=$access_token"
    );
}

?>

最初の呼び出しで 60 日間のアクセス トークンを取得します。次の呼び出しで、別の (同じ名前の可能性がある) 60 日間のトークンを取得することを期待しています変わりますが、時代は変わりません。私のシナリオの何が問題になっていますか?

4

1 に答える 1

1

トークンを相互に比較しましたか? 同じ呼び出しが 24 時間以内に行われると、Facebook から既存のアクセス トークンが返されます。また、ユーザーのページ トークンも要求した場合、トークンは期限切れにならないように設定されます。ここで私の回答を参照してください: Facebook ページ アクセス トークン - これらは期限切れになりますか? このテーマの詳細については。

毎回新しいトークンを確実に取得する方法の 1 つは、/PROFILE_ID/permissions に対して http DELETE 呼び出しを行い、新しいトークンを要求してアクセスを取り消す場合です。これに関する唯一の悪い点は、ユーザーを再度 oAuth ダイアログに通す必要があることです。

于 2013-01-29T15:13:52.243 に答える