以下代码为我提供了朋友的ID。我想要做的是获得朋友的性别,但没有取得任何成功。我可以使用生成的ID运行另一个循环,但效率不高。是否有查询将提供朋友的姓名和性别。该应用的权限是friends_about_me。此权限是否足以让朋友获得性别?
<?php
$app_id = '******';
$app_secret = '*****';
$my_url = 'http://apps.facebook.com/****/';
$code = $_REQUEST["code"];
//auth user
if(empty($code)) {
$dialog_url = 'https://www.facebook.com/dialog/oauth?client_id='
. $app_id . '&redirect_uri=' . urlencode($my_url) ;
echo("<script>top.location.href='" . $dialog_url . "'</script>");
}
//get user access_token
$token_url = 'https://graph.facebook.com/oauth/access_token?client_id='
. $app_id . '&redirect_uri=' . urlencode($my_url)
. '&client_secret=' . $app_secret
. '&code=' . $code;
$access_token = file_get_contents($token_url);
// Run fql query
$fql_query_url = 'https://graph.facebook.com/'
. '/fql?q=SELECT+uid2+FROM+friend+WHERE+uid1=me()'
. '&' . $access_token;
$fql_query_result = file_get_contents($fql_query_url);
$fql_query_obj = json_decode($fql_query_result, true);
echo $fql_query_result;
答案 0 :(得分:0)
您只需要一个FQL查询即可获取用户朋友的性别信息:
SELECT uid, name, sex FROM user WHERE uid IN (SELECT uid2 FROM friend WHERE uid1 = me())
这是根据Facebook Developers FQL main page上的样本改编的。
请注意,并非所有用户都有已发布的性别,因此您在编写代码时应考虑到这一点。