1

所以这工作正常......但是当我刷新页面两次(或快速单击包含此脚本的两个页面)时,它会给出此错误 OAuthException:必须使用活动访问令牌来查询有关当前用户的信息。有任何想法吗?

<?php

  $app_id = '***************';
  $app_secret = '**************';
  $app_namespace = '****************';

  $app_url = 'http://apps.facebook.com/' . $app_namespace . '/';
  $scope = 'email,publish_actions';

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

   // Get the current user
   $user = $facebook->getUser();

   // If the user has not installed the app, redirect them to the Login Dialog

   if (!$user) {
     $loginUrl = $facebook->getLoginUrl(array(
       'scope' => $scope,
       'redirect_uri' => $app_url,
     ));

     print('<script> top.location.href=\'' . $loginUrl . '\'</script>');
   }

if ($user) {
  try {
    // Proceed knowing you have a logged in user who's authenticated.
    $user_profile = $facebook->api('/me', 'POST');
  } catch (FacebookApiException $e) {
    error_log($e);
    $user = null;
  }
}
//<img src="https://graph.facebook.com/?php echo $user; ?/picture">
//?php print_r($user_profile); ?
?>
4

1 回答 1

1

我个人觉得管理自己更容易access_token。Facebook 的 Graph API 通过要求access_token传入一个来保护受保护的端点。PHP SDK 将这一点抽象出来,但我对 Facebook 处理这些信息并不感到满意,因为有时它根本不起作用。这并不是说这个库不好,只是说我没有正确使用它。请记住这一警告。

看起来您正在使用 Facebook Canvas 应用程序。当用户第一次成功认证时,Facebook 会发送一个access_tokenin $_GET。此时,您应该将其保存到您的数据库中,因为该访问令牌可以使用 3 个月左右。

此时,您可以在access_token调用参数中传入:

try {
    $user_profile = $facebook->api('/me', 'POST', array(
        "access_token" => ''    // access token goes here
    ));
} catch (FacebookApiException $e) {
    // error handling
}

鉴于 Facebook 正在返回您需要访问令牌才能调用/me资源的错误,它看起来$facebook->getUser();正在返回一些东西。您可能需要仔细检查它是什么。


当我在这里时,您正在使用以下逻辑:

if (!conditional) {
    // do something
}
if (conditional) {
    // do something else
}

令人困惑。使用else

if (conditional) {
    // do something
} else {
    // do something else
}
于 2013-03-24T21:10:32.627 回答