如何在offline_access许可文档的描述去除创建一个非过期的Facebook页面令牌(How

2019-10-17 06:48发布

我想创建,我可以用我的网站上,使我的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的访问令牌调试检查,并表明它有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

命令刚给我的错误:“消息”:“出现未知错误”,“类型”:“OAuthException”,“代码”:1。

那么我想,也许是因为我的用户访问令牌不长住,它不会产生长寿命的页面标记。 所以我用我的用户令牌使用相同的命令来扩展它,它只是返回同样的道理回来没有延续到期。

任何人都可以提供一些见解,以什么我做错了,我怎么可以创建此未过期的页面令牌?

Answer 1:

阅读再仔细的说明 - 根据你的描述你:

  • 获得一个短用户令牌
  • 得到一个短页面令牌从/ ME /账户
  • 试图延长短网页凭证

你应该做的是:

  • 得到一个短的用户令牌(如果客户端身份验证)
  • 交换,在相当长的用户令牌(或者你已经有很长的用户令牌,如果你使用的服务器端OAuth流)
  • 使用长用户令牌检索(长)页面访问令牌


文章来源: How to create a non-expiring Facebook page token as described in the Removal of offline_access permission doc