1

Facebook ページに投稿するために自分のサイトで使用できる無期限のページ トークンを作成しようとしています。このドキュメントのシナリオ 5 によると、これを実行できるはずです。

https://developers.facebook.com/roadmap/offline-access-removal/

私の問題は、ページ トークンを生成すると、1 時間で期限切れになることです。

私がやっていることは、このコードを使用して、ログイン時にユーザー アクセス トークンを表示することです。これはグラフ API エクスプローラーが提供するトークンと同じだと思いますが、よくわかりません。

require '../src/facebook.php';

$facebook = new Facebook(array(
  'appId'  => 'app_id',
  'secret' => 'app_secret',
));   

$user = $facebook->getUser();

if ($user) {
  try {
    $user_profile = $facebook->api('/me');
  } catch (FacebookApiException $e) {
    error_log($e);
    $user = null;
  }   
}     

if ($user) {
  $logoutUrl = $facebook->getLogoutUrl( array(

                'scope'         => 'read_stream,publish_stream,publish_actions,manage_pages,email,user_checkins',
                ));
} else {
  $loginUrl = $facebook->getLoginUrl();
}
echo $loginUrl;

$me = $facebook->api('/me');

?>
<!doctype html>
<html xmlns:fb="http://www.facebook.com/2008/fbml">
  <head>
    <title>php-sdk</title>
  </head>
  <body>
    <h1>php-sdk</h1>

    <?php if ($user): ?>
      <a href="<?php echo $logoutUrl; ?>">Logout</a>
    <?php else: ?>
      <div>
        Login using OAuth 2.0 handled by the PHP SDK:
        <a href="<?php echo $loginUrl; ?>">Login with Facebook</a>
      </div>
    <?php endif ?>

    <h3>PHP Session</h3>
    <pre><?php print_r($_SESSION); ?></pre>

    <?php if ($user): ?>
      <h3>You</h3>
      <img src="https://graph.facebook.com/<?php echo $user; ?>/picture">

      <h3>Your User Object (/me)</h3>
      <pre><?php print_r($user_profile); ?></pre>
    <?php else: ?>
      <strong><em>You are not Connected.</em></strong>
    <?php endif ?>

  </body>
</html>

次に、このグラフ API コマンドでそのトークンを使用します。

https://graph.facebook.com/me/accounts?access_token=<access_token>

これにより、すべてのページとアプリ、およびそれぞれのページ/アプリ トークンのリストが表示されます。

次に、使用したいページ トークンを取得し、Facebook Access Token Debugger で確認すると、有効期限が 1 時間あることが示されます。そこで、次のコマンドを使用して、投稿した最初の URL に記載されているように、60 日間のトークンと交換してみます。

https://graph.facebook.com/oauth/access_token?client_id=client_id&client_secret=client_secret&grant_type=fb_exchange_token&fb_exchange_token=access_token

このコマンドは、"message": "An unknown error has occurred.","type": "OAuthException", "code": 1 というエラーを表示します。

次に、ユーザー アクセス トークンの有効期間が長くないため、有効期間の長いページ トークンが生成されない可能性があると考えました。そのため、同じコマンドでユーザートークンを使用して延長しましたが、有効期限が延長されていない同じトークンが返されます。

私が間違っていることと、この無期限のページトークンを作成する方法について、誰かが洞察を提供できますか?

4

1 に答える 1

4

説明をもう一度注意深く読んでください - あなたの説明に基づいて、あなたは:

  • 短いユーザー トークンの取得
  • /me/accounts から短いページ トークンを取得する
  • 短いページ トークンを拡張しようとしています

あなたがすべきことは次のとおりです。

  • 短いユーザー トークンの取得 (クライアント側認証の場合)
  • それを長いユーザー トークンと交換します (または、サーバー側の oauth フローを使用した場合は、既に長いユーザー トークンを持っています)。
  • 長いユーザー トークンを使用して (長い) ページ アクセス トークンを取得する
于 2012-10-07T16:53:07.353 に答える