4

当用户打开我的画布应用程序时,我signed_request从 Facebook 获得一个,从中派生出user_idand oauth_token。然后我怎样才能获得access_token并检查/获取用户权限和其他数据?

4

3 回答 3

5

你说的oauth_token也是用户access_token,应该是完全一样的。

要检查用户权限,您可以对 /me/permissions 进行 GET 调用,这应该返回类似于以下的数据数组

{
  "data": [
    {
      "installed": 1, 
      "read_stream": 1, 
      "manage_notifications": 1, 
      "manage_pages": 1, 
      "user_likes": 1, 
      "user_activities": 1, 
      "user_interests": 1, 
      "user_photos": 1, 
      "user_about_me": 1, 
      "type": "permissions"
    }
  ]
}

根据您希望访问的其他数据,您需要请求更多权限,然后调用适当的 API 端点。例如获取用户的基本信息拨打电话/me或获取他们的朋友列表/me/friends

您可以在https://developers.facebook.com/docs/reference/api/permissions/找到您可以要求的所有权限

以及有关在 API 中调用何处以检索您在此处所需的不同数据位的所有信息https://developers.facebook.com/docs/reference/api/

于 2011-11-01T18:31:44.430 回答
1

当您说您拥有他们的“oauth 令牌”时-您确定这不是访问令牌吗?您可以尝试/me/permissions使用该令牌进行 API 调用并查看它是否正常工作吗?它应该返回用户授予您的应用程序的权限列表(可通过该令牌使用)

于 2011-11-01T18:08:52.433 回答
-1
    <?php
include '../../src/config.php';
// Get User ID
$user = $facebook->getUser();

// We may or may not have this data based on whether the user is logged in.
//
// If we have a $user id here, it means we know the user is logged into
// Facebook, but we don't know if the access token is valid. An access
// token is invalid if the user logged out of Facebook.

if ($user) {
  try {
    // Proceed knowing you have a logged in user who's authenticated.
    $user_profile = $facebook->api('/me');
  } catch (FacebookApiException $e) {
    error_log($e);
    $user = null;
  }
}

// Login or logout url will be needed depending on current user state.
if ($user) {
  $logoutUrl = $facebook->getLogoutUrl();
  $access_token = $facebook->getAccessToken();
$user_xml = "<?xml version=\"1.0\"?>\n"; 
$user_xml .= "<roots>\n";
$user_xml .= "<access>\n";
$user_xml .= "<token>" . $access_token . "</token>\n"; 
$user_xml .= "</access>\n";
$user_xml .= "</roots>\n";
echo $user_xml; 



} else {
  $loginUrl = $facebook->getLoginUrl();
}




?>
于 2011-11-07T15:23:23.730 回答