如何从Facebook应用程序注销用户,但保持从Facebook登录

时间:2012-03-20 08:51:57

标签: facebook facebook-javascript-sdk facebook-php-sdk logout

我已经尝试过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>

1 个答案:

答案 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都来自我(非常)有限的知识以及我所发现的。