Próbuję wyprowadzić mój kanał Facebooka do elementu div.Aktywny token dostępu musi być użyty do zapytania informacji o bieżącym użytkowniku
Stosując ten kod:
<script>
window.fbAsyncInit = function() {
FB.init({
appId : 'APP ID HERE',
xfbml : true,
version : 'v2.1'
});
FB.getLoginStatus(function(response) {
if (response.status === 'connected') {
console.log('Logged in.');
}
else {
console.log('initiate FB login...');
FB.login();
}
});
FB.api('/me/feed',function(response){
var idDiv=document.getElementById('result');
idDiv.textContent=JSON.stringify(response);
});
};
(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/sdk.js";
console.log(js.length);
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));
</script>
<div id='result'></div>
otrzymuję „zalogowany” wyświetlane na konsoli, więc wiem, że FB.getLoginStatus()
powrócił connected
.
Element div
zostanie wypełniona z powodu następującego błędu:
{"error":{"message":"An active access token must be used to query information
about the current user.","type":"OAuthException","code":2500}}
Jeśli FB.getLoginStatus()
powrócił connected
, nie powinno tam być aktywnym token dostępu?
trochę więcej informacji, jeśli chcesz dodać go do odpowiedzi: getLoginStatus nie tylko sprawdzić, czy użytkownik jest uprawniony, ale także odświeża użytkownikowi sesja. dlatego ważne jest wykonywanie wywołań api po "podłączeniu". – luschn
Pewnie, dziękuję za wyjaśnienia. – jvanstry
Dzięki, przyjacielu. Mi to pasuje. –