FB.init({
    appId            : '{your-app-id}',
    autoLogAppEvents : true,
    status           : true,
    xfbml            : true,
    version          : 'v2.9' // or v2.8, v2.7, v2.6, v2.5, v2.4, v2.3,
});Then I followed https://developers.facebook.com/docs/php/howto/example_access_token_from_javascript to log into FB as follows:# /js-login.php
$fb = new Facebook\Facebook([
  'app_id' => '{app-id}',
  'app_secret' => '{app-secret}',
  'default_graph_version' => 'v2.9',
]);
$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;
}Everything is good, right? No. I kept getting invalid access token but there's nowhere to find errors. There's no log. What do I do to get a valid $accessToken that is set and can be used to log a Facebook user into my web app?Solution #1
Make sure you include "cookie: true" in your FB.init's parameters. Why such important information isn't mentioned on https://developers.facebook.com/docs/javascript/reference/FB.init/v2.9 beats me. Your FB.init() parameters should look like the following:
FB.init({
    appId            : '{your-app-id}',
    autoLogAppEvents : true,
    status           : true,
    xfbml            : true,
    cookie           : true,
    version          : 'v2.9' // or v2.8, v2.7, v2.6, v2.5, v2.4, v2.3,
});Try again.Solution #2
Delete all cookies in the web browser for your web app and try again.
Questions? Let me know!
















 
 
 Posts
Posts
 
 
 
