Подтвердить что ты не робот

Вызывается FB.logout() без токена доступа

Я пытаюсь выйти из веб-сайта, который я создал с помощью Facebook. Вход в систему работает нормально, но когда я хочу выйти из Firebug, он дает мне такую ​​ошибку:

FB.logout(), вызываемый без токена доступа.

Я использую SDK для JavaScript в Facebook, и код, который у меня есть, выглядит следующим образом:

$(document).ready($(function () {
    $("#fblogout").click(facebooklogout);
}));

function facebooklogout() {
    FB.logout(function (response) {
    }
)};

Это код выхода, указанный в Документах разработчиков для разработчиков Facebook, с помощью кнопки, которой присваивается метод document.ready

Перед этим кодом у меня есть метод FB.init(), который работает нормально.

Если у кого-то есть решение, почему FB.logout не имеет токена доступа, это будет оценено.

4b9b3361

Ответ 1

Чтобы выйти из приложения, использующего API-интерфейс facebook, используйте этот JavaScript на странице выхода из системы сразу после тега <form>:

window.onload=function()
{
    // initialize the library with your Facebook API key
    FB.init({ apiKey: 'b65c1efa72f570xxxxxxxxxxxxxxxxx' });

    //Fetch the status so that we can log out.
    //You must have the login status before you can logout,
    //and if you authenticated via oAuth (server side), this is necessary.
    //If you logged in via the JavaScript SDK, you can simply call FB.logout()
    //once the login status is fetched, call handleSessionResponse
    FB.getLoginStatus(handleSessionResponse);
}

//handle a session response from any of the auth related calls
function handleSessionResponse(response) {
    //if we dont have a session (which means the user has been logged out, redirect the user)
    if (!response.session) {
        window.location = "/mysite/Login.aspx";
        return;
    }

    //if we do have a non-null response.session, call FB.logout(),
    //the JS method will log the user out of Facebook and remove any authorization cookies
    FB.logout(handleSessionResponse);
}

Код работает и работает на моем сайте.

Ответ 2

Я пошел на менее тривиальное решение:

    function facebookLogout(){
        FB.getLoginStatus(function(response) {
            if (response.status === 'connected') {
                FB.logout(function(response) {
                    // this part just clears the $_SESSION var
                    // replace with your own code
                    $.post("/logout").done(function() {
                        $('#status').html('<p>Logged out.</p>');
                    });
                });
            }
        });
    }

Ответ 3

Должно быть нечто подобное. Было внесено изменение в JS API, где вам нужно использовать authResponse, а не только сеанс.

//handle a session response from any of the auth related calls
function handleSessionResponse(response) {

    //if we dont have a session (which means the user has been logged out, redirect the user)
    if (!response.authResponse) {
        return;
    }

    //if we do have a non-null response.session, call FB.logout(),
    //the JS method will log the user out of Facebook and remove any authorization cookies
    FB.logout(response.authResponse);
}

Ответ 4

Я пробовал что-то вроде этого:

function fbLogout(){
    if(typeof FB.logout == 'function'){
        if (FB.getAuthResponse()) {
         FB.logout(function(response) { window.location.href = PROJECT_PATH + '/index/logout'; }); 
         return;
        }  
    };

    window.location.href = PROJECT_PATH + '/index/logout'; 
    return;  
}

Ответ 5

Ошибка говорит о том, что у вас нет токена доступа, вам нужно проверить его с помощью функции FB.getAccessToken().

Если нет токена доступа, функция возвращает null. См. Пример ниже:

   function facebooklogout() {
    try {
        if (FB.getAccessToken() != null) {
            FB.logout(function(response) {
                // user is now logged out from facebook do your post request or just redirect
                window.location.replace(href);
            });
        } else {
            // user is not logged in with facebook, maybe with something else
            window.location.replace(href);
        }
    } catch (err) {
        // any errors just logout
        window.location.replace(href);
    }
   }