我基本上复制了Facebook API建议的代码,但在登录时,它返回以下错误:
Facebook SDK返回错误:跨站点请求伪造验证失败了。URL和会话的"state"参数不匹配。
login.php(相关部分)
session_start();
require_once __DIR__ . '/facebook/autoload.php';
$fb = new Facebook'Facebook([
'app_id' => '***',
'app_secret' => '***',
'default_graph_version' => 'v2.2',
]);
$helper = $fb->getRedirectLoginHelper();
$permissions = ['email', 'user_likes']; // Optional permissions
var_dump($_SESSION, TRUE);
$loginUrl = $helper->getLoginUrl('http://'.$_SERVER['HTTP_HOST'].'/callback.php', $permissions);
我发现当我var_dump($_SESSION)
(或print_r
)时,登录成功,因为发送了正确的会话状态。
我不知道为什么var_dump
解决了这个问题。我该怎么修理它?谢谢。
这真的很奇怪,但事实证明这是一个webkit错误,并通过添加favicon
到网站,它的工作原理。"——"