ここでは、ユーザーが自分のサイトからログアウト ボタンを押すと、ユーザーをログアウトしたままにすることができません。彼はログイン ページにリダイレクトされますが、updateButton 関数は、再度ログインするのと同じ資格情報で再度呼び出されます。いくつかの方法を試しましたが、問題は解決しません。コンソールに「FB.logout がアクセス トークンなしで呼び出されました」というエラーが表示されるため、ここで updateButton 関数を正しく実行していないと思います。また、FB.logout() も正しく実行されていません。コードは次のとおりです。
$(function(){
var button;
window.fbAsyncInit = function(){
FB.init({ appId : 'myAppId',
status : true,
cookie : true,
xfbml : true,
oauth : true
});
function updateButton(response) {// I am not sure I am doing it right here
console.log("Update Button Fired.");
console.log(response);
button = document.getElementById('fb-auth');
if(response.status === 'connected')
{
FB.api('/me', function(info)
{
login(response,info);
});
}
else
{
FB.login(function(response)
{
if(response.status === 'not_authorized')
{
FB.api('/me', function(info){
login(response, info);
});
}
else
{
}
}, {scope:'email, user_birthday,user_about_me' });
}
}
}
FB.getLoginStatus(updateButton);
FB.Event.subscribe('auth.statusChange', updateButton);
};
(function() {
var e = document.createElement('script');
e.async = true;
e.type = 'text/javascript';
e.src = document.location.protocol + '//connect.facebook.net/en_US/all.js';
document.getElementById('fb-root').appendChild(e);
})();
function login(response,info){
console.log('login Showloader called');
if (response.authResponse) {
var accessToken = response.authResponse.accessToken;
$.post("/web/register/faceBookRegistration",{ data:info,accessTokenValue:accessToken}).done( function(data){
if(typeof(data) != undefined){
window.location = "/web/login/loadViewFaceLogin";
}
});
}
}
function logout(response){
FB.logout(function(response){
console.log("User is now logged out");
});
}
});
また、ログアウトすると思います
function logout(response){
FB.logout(function(response){
console.log("User is now logged out");
});
}
は正しくありません。コンソールには、FB.logout がアクセス トークンなしで呼び出されたことが示されています。何が原因でしょうか