我已经尝试过PHP SDK(v.3.1.1)和当前的Javascript SDK 如下所示:https://developers.facebook.com/docs/guides/web/
现在在尝试注销时我已经尝试了两个FB.logout()(对于js) 和$ facebook-> getLogoutUrl();
作为明确说明这些方法的文件 将用户登录到应用程序以及他们的facebook会话。
但我只需要将用户从facebook应用程序(测试站点)中注销。
我已经尝试将用户从测试网站中删除,忽略了facebook 方面。但在这种情况下,当用户再次单击登录按钮时, 登录流程(facebook身份验证和重定向)不会发生。
我也尝试过:(正如以前未解决的问题所建议的那样)
$facebook->destroySession();
unset($_SESSION['fb_' . sfConfig::get('app_fb_config_id') . '_code']);
unset($_SESSION['fb_' . sfConfig::get('app_fb_config_id') . '_access_token']);
unset($_SESSION['fb_' . sfConfig::get('app_fb_config_id') . '_user_id']);
然而,当重定向到登录页面时,$ facebook-> getUser()仍然是 检索用户。
注意: 根据文档示例,我使用php sdk将用户登录到我的测试站点, 和js sdk,以呈现和促进facebook登录按钮。
附加:
我使用的身份验证基本上就是文档建议的内容:
<?php
define('YOUR_APP_ID', 'YOUR APP ID');
//uses the PHP SDK. Download from https://github.com/facebook/php-sdk
require 'facebook.php';
$facebook = new Facebook(array(
'appId' => YOUR_APP_ID,
'secret' => 'YOUR APP SECRET',
));
$userId = $facebook->getUser();
?>
<html>
<body>
<?php if ($userId) {
$userInfo = $facebook->api('/' + $userId); ?>
Welcome <?= $userInfo['name'] ?>
<?php } else { ?>
<div id="fb-root"></div>
<fb:login-button></fb:login-button>
<?php } ?>
<script>
window.fbAsyncInit = function() {
FB.init({
appId : '<?= YOUR_APP_ID ?>',
status : true,
cookie : true,
xfbml : true,
oauth : true,
});
FB.Event.subscribe('auth.login', function(response) {
window.location.reload();
});
};
(function(d){
var js, id = 'facebook-jssdk'; if (d.getElementById(id)) {return;}
js = d.createElement('script'); js.id = id; js.async = true;
js.src = "//connect.facebook.net/en_US/all.js";
d.getElementsByTagName('head')[0].appendChild(js);
}(document));
</script>
</body>
</html>
答案 0 :(得分:5)
拿你的代码,稍微修改一下:
<?php
define('YOUR_APP_ID', 'YOUR APP ID');
//uses the PHP SDK. Download from https://github.com/facebook/php-sdk
require 'facebook.php';
$facebook = new Facebook(array(
'appId' => YOUR_APP_ID,
'secret' => 'YOUR APP SECRET',
));
session_start();
$userId = $facebook->getUser();
if ($userId && !isset($_SESSION['fbdata'])) {
$_SESSION['fbdata'] = array("userid" => $userId);
}
?>
<html>
<body>
<?php if ($userId) {
$userInfo = $facebook->api('/' + $userId); ?>
Welcome <?= $userInfo['name'] ?>
<?php } else { ?>
<div id="fb-root"></div>
<fb:login-button></fb:login-button>
<?php } ?>
<script type="text/javascript">
window.fbAsyncInit = function() {
FB.init({
appId : '<?= YOUR_APP_ID ?>',
status : true,
cookie : true,
xfbml : true,
oauth : true,
});
FB.Event.subscribe('auth.login', function(response) {
window.location.reload();
});
};
(function(d){
var js, id = 'facebook-jssdk'; if (d.getElementById(id)) {return;}
js = d.createElement('script'); js.id = id; js.async = true;
js.src = "//connect.facebook.net/en_US/all.js";
d.getElementsByTagName('head')[0].appendChild(js);
}(document));
</script>
</body>
</html>
我刚刚将用户数据保存到会话中。 现在,如果您使用此方法,当用户进入您的页面时,您应该检查他是否已经有一个会话,如果是这样,一切都很好,不需要对他进行身份验证。
如果您想要将用户从应用中注销,而不是从Facebook中注销,只需销毁该会话:
session_start();
session_destroy();
这应删除您为用户保存的所有数据,下次访问您的网页时,您可以重新开始。
我不是一个php程序员,我在这里使用的所有php都来自我(非常)有限的知识以及我所发现的。