javascript - 为什么这个 Facebook javascript-sdk 登录代码会一次又一次自动登录用户?

标签 javascript facebook facebook-javascript-sdk

在这里,一旦用户从我的网站按下注销按钮,我就无法让用户保持注销状态。他被重定向到登录页面,但使用与他再次登录相同的凭据再次调用 updateButton 函数。我尝试了多种方法,但问题仍然存在。我想我在这里的 updateButton 函数中没有正确执行操作,而且 FB.logout() 也没有正确执行,因为我在控制台中收到错误“FB.logout 在没有访问 token 的情况下调用”。 代码如下:-

            $(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 在没有访问 token 的情况下调用。可能是什么原因

最佳答案

我冒昧地重写了你的代码,保留了你的基础:

   // File - fb-init.js

    window.fbAsyncInit = function() {
        FB.init({
            appId      : app_id,
            status     : false,
            cookie     : true,
            xfbml      : true
        });
    };

    (function(d){
        var js, id = 'facebook-jssdk', ref = d.getElementsByTagName('script')[0];
        if (d.getElementById(id)) {return;}
        js = d.createElement('script'); js.id = id; js.async = true;
        js.src = "//connect.facebook.net/en_US/all.js";
        ref.parentNode.insertBefore(js, ref);
    }(document));

-

    // File - main.js

    $('#fb-login').on('click', function() {
        FB.getLoginStatus(function(responseStatus) {
            if (responseStatus.status === 'connected') {
                FB.api('/me', function(responseMe) {
                    if (!responseMe.id) 
                        return false;
                    var accessToken = responseMe.authResponse.accessToken;
                    $.post('/web/register/faceBookRegistration' {
                        data                : responseMe,
                        accessTokenValue    : accessToken
                    }).done(function(data) {
                        if (typeof(data) !== 'undefined')
                            window.location = '/web/login/loadViewFaceLogin';    
                    });   
                });
            }
            else if (responseStatus.status === 'not_authorized') {
                FB.login(function(responseLogin) {
                    FB.api('/me', function(responseMe) {
                    if (!responseMe.id) 
                            return false;
                        var accessToken = responseMe.authResponse.accessToken;
                        $.post('/web/register/faceBookRegistration' {
                            data                : responseMe,
                            accessTokenValue    : accessToken
                        }).done(function(data) {
                            if (typeof(data) !== 'undefined')
                                window.location = '/web/login/loadViewFaceLogin';    
                        });   
                    });
                }, {scope:'email, user_birthday,user_about_me' });    
            }
            else
                return false;
        });    
    });

    $('#fb-logout').on('click', function() {
        FB.logout(function(responseLogout) {

        });    
    });

关于javascript - 为什么这个 Facebook javascript-sdk 登录代码会一次又一次自动登录用户?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15682853/

相关文章:

javascript - 选择并显示外部div中的内容

iOS Facebook FQL 问题

facebook - 寻找 page_stories_by_story_type 和 page_consumptions_by_consumption_type 的类型详细信息

javascript - 如何使用 javascript 将用户 friend 连接的 facebook graph api 响应存储到变量或数组以便稍后使用

javascript - element.children 的 console.log 显示长度为 0,但稍后展开时有 3 个条目

javascript - 获取 jquery tmpl 中的索引

php - 如何清除Facebook App对象的数据

javascript - 无法从 Facebook 获取登录状态

angular - 在 Angular 2 中使用 Facebook Javascript SDK 时从 FB.getLoginStatus 内部访问变量

javascript - IE 中的 DOM 问题