我知道有关于#34的问题有很多关于stackoverflow的帖子; CSRF状态令牌与提供的不匹配。"但是,我试过并没有解决这个问题。你能看一下我下面的代码吗?请告诉我您的想法以及如何解决问题。我已经更新到最新的PHP SDK版本。
<?
require_once ('src/facebook.php');
require_once ('src/fbconfig.php');
//Facebook Authentication part
$user_id = $facebook->getUser();
$loginUrl = $facebook->getLoginUrl(array(
'scope' => 'publish_stream')
);
if ($user_id) {
$_SESSION['user_id'] = $user_id;
echo "<script>top.location.href = 'https://www.example.com/app-folder/welcome'</script>";
exit;
}
?>
.
.
<body>
<?php echo '<a href="'.$loginUrl.'" target="_top">Please login</a>'; ?>
.
.
</body>
答案 0 :(得分:11)
getLoginUrl()
生成一个新令牌。如果您的用户已经登录(使用$user_id = $facebook->getUser()
),那么您最终将获得2个令牌。
如果用户已经过身份验证,请不要询问$ loginUrl。
$user_id = $facebook->getUser();
if ($user_id) {
$_SESSION['user_id'] = $user_id;
echo "<script>top.location.href = 'https://www.example.com/app-folder/welcome'</script>";
exit;
} else {
$loginUrl = $facebook->getLoginUrl(array(
'scope' => 'publish_stream')
);
}
&GT;
答案 1 :(得分:0)
我必须做以下事情:
我确信主要问题是我在每一页上都打了 getLoginUrl 。
由于我进行了这些更改,因此当机器人点击我的网页时,我只会在日志中收到“CSRF状态令牌”错误。
答案 2 :(得分:0)
尽管Facebook PHP API文档中没有说明,但您必须为PHP会话配置apache才能使登录过程正常工作。结果证明,当我们得到“CSRF状态令牌与提供的令牌不匹配”时,我们遇到的问题。
确保您使用的服务器池设置为使用memcache来获取会话信息,否则apache将在本地写入会话信息,如果下一个请求未转到同一服务器,您将获得“CSRF状态令牌与提供的令牌不匹配。”
这是在开发环境中(有一台服务器)就像魅力一样但在生产中失败的事情之一。
我们还必须重新配置我们的CDN设置,以确保我们通过PHP Session cookie。
答案 3 :(得分:-3)
解决方法:
转到base_facebook.php
寻找protected function getCode()
这就是问题所在
$this->state
变量不会保留用于场外导航(自然)
替换这个:
if ($this->state !== null &&
isset($_REQUEST['state']) &&
$this->state === $_REQUEST['state']) {
用这个:
if ($_REQUEST['state'] != '' && $_REQUEST['code'] != '') {
它会很好用