Facebook PHP / JS Sdk此授权码已被使用错误

时间:2014-09-27 12:00:06

标签: facebook-graph-api facebook-javascript-sdk facebook-php-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 php sdk:https://github.com/facebook/facebook-php-sdk-v4

谢谢。

2 个答案:

答案 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有一些不好的值