API do Facebook: faça o login usando o SDK do JavaScript e verifique o estado de login com o PHP

Estou usando o SDK de JavaScript do Facebook para abrir um Login de Login quando o usuário clicar no botão de Login.

O código é, como o Facebook fornece na duplicação:

$(".loginButton").click(function(){ FB.login(function(response) { FB.api('/me', function(response) { console.log(response.id); //User ID shows up so I can see that the user has accepted the app. }); }); 

Também posso usar FB.getLoginStatus() para verificar se o usuário efetivamente fez login e aceitou o aplicativo.

No entanto, agora eu gostaria de executar uma function com PHP. Tanto quanto eu entendo, o PHP tem $user atribuído o ID de $user após um login bem-sucedido.

O problema é depois que o $user JS Login $user ainda é 0 . Estou preso e não consigo descobrir por que ele não atribuirá a identificação de usuário correta para $user

Aqui está o meu JS:

   window.fbAsyncInit = function() { FB.init({ appId : '', status : true, // check login status cookie : true, // enable cookies to allow the server to access the session xfbml : true, channelUrl : 'channel.php' // custom channel }); }; //Get Login Status function amILoggedIn(){ var toreturn = ""; FB.getLoginStatus(function(response) { if (response.status === 'connected') { window.userId = response.authResponse.userID; toreturn = "GetLoginStatus: logged in" + " " + ""; } else { toreturn = "GetLoginStatus: Logged Out"; } console.log(toreturn); }); }; // Load the SDK asynchronously (function(d, s, id){ var js, fjs = d.getElementsByTagName(s)[0]; if (d.getElementById(id)) {return;} js = d.createElement(s); js.id = id; js.src = "//connect.facebook.net/en_US/all.js"; fjs.parentNode.insertBefore(js, fjs); }(document, 'script', 'facebook-jssdk')); var obj = { method: 'feed', link: 'http://www.google.com' }; $(".loginPopupButton").click(function(){ FB.login(function(response) { FB.api('/me', function(response) { //user-specific stuff console.log(response.id); }); }); });  

E aqui está o PHP:

   $AppId, 'secret' => $AppSecret )); //Facebook Authentication part $user = $facebook->getUser(); $perms = "manage_pages"; if(isset($_GET['backlink'])) $redirectUrl = urldecode($_GET['backlink']); else $redirectUrl = $fullserverpath; $cancelUrl = $ServerPath."index.php?page=loginWFb"; //AA - where to go to get FB popup. $loginUrl = $facebook->getLoginUrl( array( 'scope' => $perms, 'redirect_uri' => $redirectUrl, 'cancel_uri' => $cancelUrl ) ); //AA- Defining that a powerUSER is someone who's logged in if(isset($user)){ $_SESSION['loggedIn'] = $user; } ?> 

O login com o JS SDK armazena os dados de login nos cookies do Facebook enquanto o login com o SDK do PHP armazena os dados na session do PHP. Então, se você logar com o JS SDK, o SDK do PHP não estará ciente disso.

Para fazer o login com o SDK do PHP usando os dados do JS SDK, você precisa chamar sua página PHP com o pedido assinado no parâmetro de consulta:

 FB.getLoginStatus(function(response) { if (response.status === 'connected') { // Full redirect or ajax request according to your needs window.location.href = 'login.php?signed_request='+response.authResponse.signedRequest; } }); 

Então $facebook->getUser() lhe dará o id do usuário no seu código PHP.

Ao inicializar o object do Facebook em PHP, tente configurar o parâmetro sharedSession como true :

 $facebook = new Facebook(array( 'appId' => $AppId, 'secret' => $AppSecret, 'sharedSession' => true )); 

você pode encontrar um exemplo de trabalho a partir daqui

http://liferaypower.blogspot.com/2013/10/index.html

Código de amostra

 FB.init({ appId: '490986011016528', // App ID channelUrl: 'http://localhost:8000/', // Channel File status: true, // check login status cookie: true, // enable cookies to allow the server to access session xfbml: true // parse XFBML }); FB.Event.subscribe('auth.authResponseChange', function(response) { if (response.status === 'connected') { document.getElementById("message").innerHTML += "ConnectedtoFacebook"; } else if (response.status === 'not_authorized') { document.getElementById("message").innerHTML += "
Failed to Connect"; //FAILED } else { document.getElementById("message").innerHTML += "
Logged Out"; //UNKNOWN ERROR } });