我该如何从用户的图像中获取Facebook相册

问题描述 投票:-1回答:1

我正在创建一个Facebook应用程序,并且我想显示带有封面图像的用户相册,我尝试使用代码#1,但这确实非常慢,因为我在foreach中调用了facebook api,这使我的应用程序永远无法使用,所以我正在寻找另一种方法来使api调用一次并获取所有信息,所以我尝试了FQL多重查询(代码2),但是现在我遇到了问题,因为如果专辑中没有图片,它将无法什么也不返回,所以请检查我的代码,如果您有任何想法我可以做到这一点,我将不胜感激

code#1
$albums = $facebook->api('/me/albums?limit=0&fields=id,name,count,cover_photo');
foreach($albums['data'] as $album)
                {
                // get all photos for album
                $photos = $facebook->api("/{$album['id']}/?fields=picture,name,count");
                $foto = $photos['picture'];
                $nombre = $album['name'];

                $id = $album['id'];
                $count = $album['count'];
                $cover_photo = $album['cover_photo'];
                $nombre = $nombre." (".$count.")";


                echo "<li> <a href=\"album.php?numero_album=$id&nombre_album=$nombre \" title=\"$nombre\"><img src=\"https://graph.facebook.com/{$cover_photo}/\" alt=\"$nombre\" /> </a> </li>";
                }


code#2
$multiQuery = '{
  "albumes":"SELECT name,cover_pid,object_id,size FROM album WHERE owner=me()",
  "portadas":"SELECT src_big FROM photo WHERE pid IN (SELECT cover_pid FROM #albumes)"
        }';

        $param = array(       
     'method' => 'fql.multiquery',       
     'queries' => $multiQuery,       
     'callback' => '');       
        $queryresults = $facebook->api($param);

                foreach($queryresults[0]['fql_result_set'] as $album)
                {
                $nombre = $album['name'];
                $id = $album['object_id'];
                $count = $album['size'];
                $nombre = $nombre." (".$count.")";


                echo "<li> <a href=\"album.php?numero_album=$id&nombre_album=$nombre \" title=\"$nombre\"><img src=\"https://graph.facebook.com/{$cover_photo}/\" alt=\"$nombre\" /> </a> </li>";
                }
facebook-graph-api facebook-fql fql.multiquery
1个回答
0
投票

所以我尝试了FQL多重查询(code#2),但是现在我遇到了问题,因为如果相册没有图像,它将什么也不会返回

© www.soinside.com 2019 - 2024. All rights reserved.