0

我对以下代码感到疯狂:

<?php
//Code of http://example.com/facebook/

require_once("../settings.php"); //Providing some settings
function authorize()
{
    header("HTTP/1.1 303 See Other");
    header("Location: https://www.facebook.com/dialog/oauth?client_id=".urlencode($GLOBALS["FacebookConfig"]["appId"])."&redirect_uri=".urlencode("http://example.com/facebook/".(isset($_GET["delete"])?'?delete':''))."&scope=read_mailbox,offline_access");
    exit();
}

require_once("SDK/facebook.php");


if(!isset($_GET["code"]))
{
    authorize();
}

$facebook = new Facebook($GLOBALS["FacebookConfig"]); //$GLOBALS["FacebookConfig"] is defined and set correctly
$user=$facebook->getUser(); //retreive User ID
if(!$user)
{
    header("HTTP/1.1 303 See Other");
    $LoginURL=$facebook->getLoginUrl();
    header("Location: ".$LoginURL); //Endless redirect here
    exit();
}
?>

我的问题是$user始终存在0,因此客户端被无限重定向。但我看不出$user总是留下来的理由0。通常它应该是当前登录的 facebook 用户的用户 ID。

编辑:$GLOBALS["FacebookConfig"]设置settings.php如下:

$GLOBALS["FacebookConfig"] = array();
$GLOBALS["FacebookConfig"]['appId'] = 'appID'; //appID replaced
$GLOBALS["FacebookConfig"]['secret'] = 'appSecret'; //appSecret replaced
$GLOBALS["FacebookConfig"]['fileUpload'] = false;
4

1 回答 1

1

我的以下代码settings.php导致了错误:

ini_set("session.use_cookies", 0);
ini_set("session.use_only_cookies", 0);
ini_set("session.use_trans_sid", 1);
ini_set('session.gc_probability', 1);
ini_set('session.gc_divisor', 1);
ini_set('session.gc_maxlifetime', 60*10);

由于我不知道这会影响 Facebook API,因此我没有将其注释掉。删除后,它工作得很好。但是我花了几个小时才发现...

于 2012-07-20T22:01:41.930 回答