Facebook api php destroySession不会破坏javascript会话/ cookie

时间:2012-02-15 17:00:21

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

我想尝试的是在退出登出时退出我的网站,但不会退出Facebook。这是我的代码的精简版本,改编自Facebook提供的示例。

当前发生的事情是,当命中注销时,会话被销毁,页面重新加载,然后事件在页面加载时订阅auth.login和auth.logout,并将页面发送到重定向循环。

我已尝试在单独的页面上注销代码部分,并为用户提供单击以返回到站点的链接,但再次在页面加载时触发auth.login并将用户重新登录。

我要问的是如何以不会将用户从Facebook注销的方式销毁会话,但不会自动在我的网站上重新授权用户。无论我尝试什么,auth.login都会自动触发并重新授权用户!

<?php


require 'include/facebook/facebook.php';

$facebook = new Facebook(array(
  'appId'  => 'API KEY',
   'secret' => 'API SECRET',
));

if(isset($_POST['logout'])){
$facebook->destroySession();



if (isset($_SERVER['HTTP_COOKIE'])) {
        $cookies = explode(';', $_SERVER['HTTP_COOKIE']);
        foreach($cookies as $cookie) {
            $parts = explode('=', $cookie);
            $name = trim($parts[0]);
            setcookie($name, '', time()-3600);
            setcookie($name, '', time()-3600, '/');
            setcookie($name, '', time()-3600, '/','MY DOMAIN');

        }
    }

    $signed_request_cookie = 'fbsr_' . API KEY;
    setcookie($signed_request_cookie, "", time()-3600, '/', 'MY DOMAIN');


}
// See if there is a user from a cookie
 $user = $facebook->getUser();

if ($user) {
  try {
    // Proceed knowing you have a logged in user who's authenticated.
    $user_profile = $facebook->api('/me');
  } catch (FacebookApiException $e) {
    echo '<pre>'.htmlspecialchars(print_r($e, true)).'</pre>';
    $user = null;
  }
}



?>
<!DOCTYPE html>
<html xmlns:fb="http://www.facebook.com/2008/fbml">
 <body>
   <?php if ($user) { ?>    


Your user profile is
  <pre>
    <?php print htmlspecialchars(print_r($user_profile, true)) ?>
  </pre>

  <form action = "" method = "post">

  <input type = "submit" name = "logout" value = "logout"/> 
  </form>
<?php } else { ?>
  <fb:login-button></fb:login-button>
<?php } ?>
<div id="fb-root"></div>
<script>
  window.fbAsyncInit = function() {
    FB.init({
      appId: '<?php echo $facebook->getAppID() ?>',
      channelUrl : '/channel.php', // Channel File
      cookie: true, 
      xfbml: true,
      oauth: true,
      status: true
    });
    FB.Event.subscribe('auth.login', function(response) {

      alert('logging');
      window.location.reload();
    });
    FB.Event.subscribe('auth.logout', function(response) {

      alert('logging out');
      window.location.reload();
    });
  };
  (function() {
    var e = document.createElement('script'); e.async = true;
    e.src = document.location.protocol +
      '//connect.facebook.net/en_US/all.js';
    document.getElementById('fb-root').appendChild(e);
  }());
</script>
<br />
POST:
<?php 
print_r($_POST);
?>

2 个答案:

答案 0 :(得分:0)

我在您的活动订阅中注意到您没有查看从通话中回复的响应,并且盲目地重新加载页面。您应该检查响应值,并且只在您真正需要时才重定向。我很惊讶Facebook JS SDK即使在响应中发现了不同的事情时也会触发这些事件。

答案 1 :(得分:0)

这感觉就像一个非常脏的方式,但我刚刚结束了包装JS Facebook初始化器,只有当有人点击FB登录按钮时才运行它。我仍然不确定这是我创建的错误还是FB API的缺陷,如果有人能以任何方式给我任何指示我会感激。

function login_fb(){


  window.fbAsyncInit = function() {
      FB.init({
        appId: '<?php echo $facebook->getAppID() ?>',
        channelUrl : '/channel.php', // Channel File
        cookie: true, 
        xfbml: true,
        oauth: true,
        status: true
      });



      FB.Event.subscribe('auth.login', function(response) {

        window.location.reload();
      });
      FB.Event.subscribe('auth.logout', function(response) {

        window.location.reload();
      });
    };
    (function() {
        var e = document.createElement('script'); e.async = true;
        e.src = document.location.protocol +
          '//connect.facebook.net/en_US/all.js';
        document.getElementById('fb-root').appendChild(e);
      }());

}


<a href ="#" onclick = "javascript:login_fb()">login</a>