我正在使用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 php sdk:https://github.com/facebook/facebook-php-sdk-v4
谢谢。
答案 0 :(得分:3)
有几种方法可以解决这个问题。
1)您必须在每次调用时更新cookie中的访问令牌,FB不会自动执行此操作。因此,请务必使用FB.init
参数调用status: true
。
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 :(得分:-1)
删除您的浏览器历史记录,因为您在之前的会话中测试过您的Cookie有一些不好的值