2013-02-03 55 views
0

我有一个Facebook应用程序,显示Facebook上的朋友创建的所有事件的计数。我使用FQL返回数字。直到2月1日,它工作正常,我认为它因为本月的滚动更改而停止工作,但我一直无法在文档中找到有关FQL协议的任何信息。这里是被之前的工作:Facebook PHP SDK FQL不起作用

$timestamp = time(); // Get current Unix time 
$iso8601 = date('c', $timestamp); // Convert unix time to ISO8601 

// FQL Multiquery 
$fql_query = '{"allFriends":"SELECT+uid2+FROM+friend+WHERE+uid1=me()",' 
      .'"allEvents":"SELECT+eid+FROM+event_member+WHERE+uid+IN+(SELECT+uid2+FROM+#allFriends)+AND+start_time>=\''.$iso8601.'\'",' 
      .'"creators":"SELECT+creator+FROM+event+WHERE+eid+IN+(SELECT+eid+FROM+#allEvents)"}' 
      . '&access_token=' . $access_token; 
// Get FQL through Graph API call 
    $fql = $facebook->api('/fql?q=' . $fql_query); 

但现在当脚本运行,我收到此异常:

FacebookApiException: OAuthException: (#601) Parser error: unexpected '{' at position 0.

我应该改变解决?

任何帮助,将不胜感激

回答

0

嗯,我从来没有想出如何修复的问题多询问,但我没有锻炼如果有人有相同的问题解决方法。 我不得不做两个独立的fql调用,并使用输出来完成我的任务。下面是代码:

$timestamp = time(); // Get current Unix time 
$iso8601 = date('c', $timestamp); // Convert unix time to ISO8601 

// FQL Queries 
//Select Events created by user's Friends 
$fql_query = 'SELECT+creator+FROM+event+WHERE+eid+IN+' . 
'(SELECT+eid+FROM+event_member+WHERE+start_time>=\'' . 
$iso8601.'\'+AND+uid+IN+(SELECT+uid2+FROM+friend+WHERE+uid1=me()))' . 
&access_token=' . $access_token; 

$fql = $facebook->api('/fql?q=' . $fql_query); 

// Get friend_count from user table 
$fql_query2 = 'SELECT+friend_count+FROM+user+WHERE+uid=me()' . 
&access_token=' . $access_token; 

$fql2 = $facebook->api('/fql?q=' . $fql_query2); 

我知道这是不是很有效,绝对难看,所以如果任何人有办法解决我原来的问题,我会很乐意接受的答案。

罗伯特

0

这个工作对我来说:

$fql = 'SELECT current_location FROM user WHERE uid = me()'; 
$result = client->api('/fql', 'GET', ['q' => $fql, 'access_token' => 'access-token-here']);