6

我正在使用Facebook的PHP和js sdk。Facebook PHP/JS Sdk此授权码已被使用错误

我使用js sdk登录facebook。登录完美。

我有php部分。

private $helper, $api_id, $app_secret, $session;   

.... 

FacebookSession::setDefaultApplication($this->api_id, $this->app_secret); 
$this->helper = new FacebookJavaScriptLoginHelper(); 


try { 
    $this->session = $this->helper->getSession(); 
} catch (FacebookRequestException $ex) { 
    log_message('error', 'Facebook e1 :' . $ex->getCode()); 
    log_message('error', 'Facebook e1 :' . $ex->getMessage()); 
} catch (\Exception $ex) { 
    log_message('error', 'Facebook e2 :' . $ex->getCode()); 
    log_message('error', 'Facebook e2 :' . $ex->getMessage()); 
} 

if ($this->session) { 
    $request = (new FacebookRequest($this->session, 'GET', '/me'))->execute(); 
    $user = $request->getGraphObject()->asArray(); 
    return $user; 
} else { 
    return false; 
} 

当页面正常加载时,我得到的用户数据没有问题。

但是,例如,如果我按f5几次,刷新页面,我得到和错误,“此授权码已被使用。”或“此授权码已过期。”用户数据为空。

想法是用js登录,并使用php部分来验证是用户登录到Facebook或不。

我使用最新的Facebook SDK PHP:https://github.com/facebook/facebook-php-sdk-v4

谢谢。

+0

这也发生在我身上。 :/ – Chuy 2014-09-29 21:26:26

+0

发生在我身上:( – ilumin 2014-10-27 09:58:51

回答

3

有几种方法可以解决这个问题。

1)您必须在每次调用时更新Cookie中的访问令牌,FB不会自动执行此操作。所以,请确保您拨打FB.initstatus: true param。

FB.init({ 
     appId  : window.fbId, 
     cookie  : true, 
     status  : true, 
     version : 'v2.3' 
    }); 

接下来,无论您是否已经连接到Facebook,每页刷新都必须拨打FB.getLoginStatus();

如果您的应用程序需要执行一些ajax调用,这仅仅是因为您在执行ajax时未更新访问令牌(除非您在每次调用ajax之前调用FB.getLoginStatus();-这已经过时了)。

2)一旦用户通过FB JS SDK连接,更好的做法是在会话中存储访问令牌。 PHP代码可能如下所示:

try { 
     $fbToken = isset($_SESSION['fbToken']) ? $_SESSION['fbToken'] : NULL; 
     if ($fbToken !== NULL) { 
      $session = new \Facebook\FacebookSession($fbToken); 
     } else { 
      $helper = new FacebookJavaScriptLoginHelper(); 
      $session = $helper->getSession(); 
     } 

    } catch(\Facebook\FacebookRequestException $ex) { 
     log_message('error', 'Facebook e1 :' . $ex->getCode()); 
     log_message('error', 'Facebook e1 :' . $ex->getMessage()); 
    } catch(\Exception $ex) { 
     log_message('error', 'Facebook e2 :' . $ex->getCode()); 
     log_message('error', 'Facebook e2 :' . $ex->getMessage()); 
    } 

    if ($session) { 
     $accessToken = $session->getAccessToken(); 
     $longLivedAccessToken = $accessToken->extend(); 
     $_SESSION['fbToken'] = $longLivedAccessToken; 
     $request = (new FacebookRequest($session, 'GET', '/me'))->execute(); 
     $user = $request->getGraphObject()->asArray(); 
     return $user; 
    } else { 
     return FALSE; 
    } 
} 

希望我确实帮了忙...... 干杯。

-1

删除浏览器历史记录,cookies这是因为你测试你的面前,然后会产生一些不良值

+0

嗯我试过另一个帐户和其他浏览器所有作品 – 2016-11-02 18:17:59

相关问题