将Facebook JS sdk中的访问令牌传递给PHP会话或cookie

时间:2016-02-07 22:31:28

标签: javascript php facebook facebook-graph-api cookies

我正在通过这个Facebook示例工作:Getting Access Token From The JavaScript SDK Example

我能够通过JS获得Facebook登录部分。 但我希望从PHP获取用户ID和访问令牌,以用于服务器端操作,例如添加,删除等。

这是我的JS部分,工作正常:

  function fb_login() {
    FB.login(function(response) {
        if (response.authResponse) {
            $.post("actions.php?js-login").done(function(data){
                console.log(data);
            });         
            init_app();
        } else {
        alert('User cancelled login or did not fully authorize.');
        }
    });
  }

这就是PHP方面似乎无法识别JS应该传输的cookie或会话:

if (isset($_GET['js-login'])) {

$helper = $fb->getJavaScriptHelper();

try {
  $accessToken = $helper->getAccessToken();
} catch(Facebook\Exceptions\FacebookResponseException $e) {
  // When Graph returns an error
  echo 'Graph returned an error: ' . $e->getMessage();
  exit;
} catch(Facebook\Exceptions\FacebookSDKException $e) {
  // When validation fails or other local issues
  echo 'Facebook SDK returned an error: ' . $e->getMessage();
  exit;
}

if (! isset($accessToken)) {
  echo 'No cookie set or no OAuth data could be obtained from cookie.';
  exit;
}

// Logged in
echo '<h3>Access Token</h3>';
var_dump($accessToken->getValue());

$_SESSION['fb_access_token'] = (string) $accessToken;
exit;

}

我得到了

  

无法设置Cookie或无法从Cookie获取OAuth数据。

消息,但用户已由JS登录。

1 个答案:

答案 0 :(得分:1)

您需要确保使用

初始化JavaScript SDK
{cookie: true}

选项集。例如:

window.fbAsyncInit = function() {
  FB.init({
    appId: 'your-app-id',
    cookie: true, // This is important, it's not enabled by default
    version: 'v2.2'
  });
};

如果您未设置此选项,则不会设置Facebook Cookie,并且PHP SDK将无法从Cookie中存在的已签名请求中获取访问令牌。

参考:https://developers.facebook.com/docs/php/howto/example_access_token_from_javascript