使用用户凭据使用javascript sdk登录facebook

使用用户凭据使用javascript sdk登录facebook,javascript,facebook,Javascript,Facebook,我正在使用Javascript sdk和facebook应用程序为用户创建登录页面。 FB.login提示用户输入facebook用户名和密码。我已保存所有信息,如用户id、访问令牌和所有信息。但是,当用户注销时。我想登录facebook而不需要再次输入用户名和密码。我想使用用户id和访问令牌直接使用javascript API登录 谢谢 function updateButton(response) { button = document.

我正在使用Javascript sdk和facebook应用程序为用户创建登录页面。 FB.login提示用户输入facebook用户名和密码。我已保存所有信息,如用户id、访问令牌和所有信息。但是,当用户注销时。我想登录facebook而不需要再次输入用户名和密码。我想使用用户id和访问令牌直接使用javascript API登录

谢谢

   function updateButton(response) {
                button       =   document.getElementById('fb-auth');
                userInfo     =   document.getElementById('user-info');

                testbut     =   document.getElementById('test');

                var rr = getResponse("user_profile.xml");

                if(rr != null)
                    {
                response = rr;
                    }
                if (response.authResponse) {alert('me/permissions/?access_token='+     


      response.authResponse.accessToken);
    FB.api('me/permissions/?access_token='+ response.authResponse.accessToken    

          ,function(response)


    {
  for (var name in response) {
               alert(response.data);
           }
        alert(response);

  });

                    //user is connected
                    FB.api('/me', function(info) {

                        login(response, info);


                    });

                    button.onclick = function() {
                        FB.logout(function(response) {
                            logout(response);
                        });
                    };
                } else {
                    //user is not connected

                    button.innerHTML = 'Login';
                    button.onclick = function() {

                        FB.login(function(response) {
                            if (response.authResponse) {
                                FB.api('/me', function(info) {
                                    login(response, info);

                                });
                            } else {
                                //user cancelled login or did not grant authorization
                                showLoader(false);
                            }
                        },  

    {scope:'email,user_birthday,status_update,publish_stream,user_about_me'});
                    }
                }
            }


            // run for the current status and whenerve it is changed
            FB.getLoginStatus(updateButton);
            FB.Event.subscribe('auth.statusChange', updateButton);
        };

        (function() {
            var e = document.createElement('script'); e.async = true;
            e.src = document.location.protocol
                + '//connect.facebook.net/en_US/all.js';
            document.getElementById('fb-root').appendChild(e);
        }());


        function login(response, info){
            if (response.authResponse) {

                ajaxFunction(response);
                var accessToken =   response.authResponse.accessToken;

                userInfo.innerHTML  = '<img src="https://graph.facebook.com/' + info.id  
                                  + "<br /> Your Access Token: " + accessToken;
                button.innerHTML  = 'Logout';
                document.getElementById('other').style.display = "block";


            }
        }

        function logout(response){
            userInfo.innerHTML  =   "";
            document.getElementById('debug').innerHTML = "";
             document.getElementById('other').style.display = "none";

        }
函数更新按钮(响应){
button=document.getElementById('fb-auth');
userInfo=document.getElementById('user-info');
testbut=document.getElementById('test');
var rr=getResponse(“user_profile.xml”);
如果(rr!=null)
{
响应=rr;
}
if(response.authResponse){alert('me/permissions/?access_token='+
response.authResponse.accessToken);
FB.api('me/permissions/?access_token='+response.authResponse.accessToken
,功能(回应)
{
for(响应中的变量名称){
警报(响应数据);
}
警报(响应);
});
//用户已连接
FB.api('/me',函数(info){
登录(响应、信息);
});
button.onclick=函数(){
FB.注销(功能(响应){
注销(响应);
});
};
}否则{
//用户未连接
button.innerHTML='Login';
button.onclick=函数(){
FB.登录(功能(响应){
if(response.authResponse){
FB.api('/me',函数(info){
登录(响应、信息);
});
}否则{
//用户已取消登录或未授予授权
showLoader(假);
}
},  
{范围:'电子邮件、用户生日、状态更新、发布流、用户关于我'});
}
}
}
//针对当前状态运行,并在更改时运行
FB.getLoginStatus(更新按钮);
FB.Event.subscribe('auth.statusChange',updateButton);
};
(功能(){
var e=document.createElement('script');e.async=true;
e、 src=document.location.protocol
+“//connect.facebook.net/en_US/all.js”;
document.getElementById('fb-root').appendChild(e);
}());
函数登录(响应、信息){
if(response.authResponse){
ajax功能(响应);
var accessToken=response.authResponse.accessToken;
userInfo.innerHTML='您的访问令牌:“+accessToken;
button.innerHTML='Logout';
document.getElementById('other').style.display=“block”;
}
}
功能注销(响应){
userInfo.innerHTML=“”;
document.getElementById('debug').innerHTML=“”;
document.getElementById('other').style.display=“无”;
}

您必须在数据库中将用户访问令牌存储给用户,以便下次使用。 下面是一些使用javascript sdk传递访问令牌的小提示

FB.api('me/permissions/?access_token=Your access token',function(response){console.log(response)});

有点晚了,但我猜您正在尝试使用过期或无效的短期访问令牌登录。对于以后的登录,您应该将短期访问令牌转换为长期访问令牌,有效期约为60天。转换为长期令牌需要在您的服务器上进行,因为这需要您的应用程序机密。详细信息ls是。长期令牌是您应该存储在数据库(或类似数据库)中的内容供将来使用。

谢谢。实际上我保存了它。我有访问令牌和用户ID。但是如何使用它们自动登录,而不需要用户在注销后输入用户名和密码。在使用javascript sdk向facebook请求时,您必须发送存储的访问令牌。我仍然无法定义响应对象。请尝试传递每个你调用“FB.api”的地方都有访问令牌。非常感谢,但实际上仍然没有定义。可能是因为我已注销。令牌不再有效。我希望能够通过它过关