我对以下代码感到疯狂:
<?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;
答案 0 :(得分: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,所以我没有对其进行评论。删除后,它完全正常。但是花了几个小时才发现......