我使用以下代码来浏览Facebook用户的状态,并对喜欢或评论该状态的所有朋友进行排序。然后我将所有这些朋友添加到我的数据库中。我遇到的问题是简单地组合两个 foreach 循环。我尝试了array_combine但没有奏效,因为我仍然有很多重复的Facebook用户,他们要么多次评论状态,要么评论并喜欢状态。
任何帮助都非常感谢。(此答案中使用的代码:Facebook Graph API - 查找用户顶级朋友)
$statuses = $facebook->api('/me/statuses');
$user_info = $facebook->api('/me');
$facebook_id = $user_info['id'];
foreach($statuses['data'] as $status){
// processing likes array for calculating fanbase.
foreach(($status['likes']['data']) as $likesData){
$frid = $likesData['id'];
$frname = $likesData['name'];
$friendArray[$frid] = $frname;
if($frid!=$facebook_id){
echo $frid .' ';
echo $frname .' ';}}
foreach($status['comments']['data'] as $comArray){
// processing comments array for calculating fanbase
$frid = $comArray['from']['id'];
$frname = $comArray['from']['name'];
if($frid!=$facebook_id){
echo $frid .' ';
echo $frname .' ';}}
}
有一个数组,您可以添加所有评论或喜欢该状态的 id:s。在将其添加到数组之前,请检查它是否还不存在。
if(!in_array($id, $user_ids_that_liked_or_commented))
{
$user_ids_that_liked_or_commented[] = $id;
}
完成所有喜欢和评论后,将那里的所有值添加到数据库中。