17

我正在使用PHP API 将旧的 FB 应用程序迁移到新的图形 API

我有两个页面:公共页面(不需要用户登录)和私人页面(需要)

所以我的应用程序中每个 php 页面的代码如下:

if (this_page_requires_user_login){
      $facebook = new Facebook(...) ;
      $session = $facebook->getSession ;
      if (!$session){
              $url =$facebook.getLoginUrl(array(next => current_page );
              echo "<fb:redirect url=$url/>" ;

}
// the rest of the code continues here

现在你可以看到,这种工作方式将每个页面转发到登录 url,虽然它可以工作,但它也很慢,并将 &session={bla} 字符串附加到非常单一的 url。

在将用户重定向到登录页面之前,我需要一种方法来检查用户已经登录的位置。但我在 php api 中找不到这样的方法。最好的方法是什么?

编辑

这似乎可以解决问题

if ($session) {
  try {
    $me = $facebook->api('/me');
    if ($me) {
       // here comes your code for user who is logged in
    }
  } catch (FacebookApiException $e) {
    login()
  }
}else{
 login()
}

function login(){

  $url =$facebook.getLoginUrl(array(next => current_page );


      echo "<fb:redirect url=$url/>" ;
}
4

1 回答 1

19

如果我正确阅读了您的代码,那么只有在没有返回会话的情况下您才会进行重定向?根据Facebook 示例中的评论,即使您恢复了会话,也不能假设它仍然有效。只有尝试需要登录用户的 API 调用才能确定。这是我见过的可靠确定登录/注销状态的最佳方法。

if ($session) {
  try {
    $me = $facebook->api('/me');
    if ($me) {
      //User is logged in
    }
  } catch (FacebookApiException $e) {
    //User is not logged in
  }
}
于 2010-07-15T02:36:52.610 回答