2

ユーザーが Facebook にログインしている場合、FB.getLoginStatus() は正常に機能します。しかし、ユーザーが Facebook にログインしていない場合、FB.getLoginStatus() コールバックは呼び出されず、コールバックを取得できないため、コードでそのケースを処理できません。私はサンドボックスモードではありません。

また、コールバックを強制するために 'true' を追加しました (eg) FB.getLoginStatus(function(response){}, true)。役に立ちませんでした。これはバグですか?まだ修正されていますか?

そうでない場合は、ユーザーが Facebook からログアウトしたときに回避策を提供してください。私は今、この問題に1週間立ち往生しています。

function GetFBLoginStatus() {
    FB.getLoginStatus(function(response) {
        alert("inside call back function"); 
        if (response.status === 'connected') {
            var uid = response.authResponse.userID;
            var accessToken = response.authResponse.accessToken; 
            alert("Connected FBID = " + uid);
        } else if (response.status === 'not_authorized') { 
            alert("not_authorized"); 
        } else {
            alert("Not Logged into facebook");
        }
        return true;
    }, true)
} 
4

2 に答える 2

5

イベントを作成できますauth.logout:

FB.Event.subscribe('auth.logout', function(response) {
    alert('logged out!');
});

または、より良い解決策として、auth.authResponseChangeイベントを作成します。

FB.Event.subscribe('auth.authResponseChange', function(response) {
    console.log('The status of the session changed to: '+response.status);
    alert(response.status);
});

アップデート:

<div id="fb-root"></div>
<script>
window.fbAsyncInit = function() {
    FB.init({
        appId  : 'APP_ID',
        status : true,
        cookie : true,
        xfbml  : true,
    });

    FB.Event.subscribe('auth.login', function(response) {
        alert('logged in');
    });

    FB.Event.subscribe('auth.logout', function(response) {
        alert('logged out');
    });     
};

function GetFBLoginStatus() {
    FB.getLoginStatus( function(response) {
        console.log(response);
        if (response.status === 'connected') {
            var accessToken = response.authResponse.accessToken;
            alert(accessToken);
        } else if (response.status === 'not_authorized') {
            //login function
            alert('login first');
        } else {
            //login function
            alert('login first');
        }
    }, true);
}

//Load the SDK Asynchronous
(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));
</script>

<div>
<a href="#" onclick="GetFBLoginStatus()"><img src="../FacebookSmall.bmp" />ddd</a>
</div>
于 2012-07-02T16:22:32.040 に答える
0

Philip さんのコメントへの返信: facebook からログアウトした後、ページを更新しようとしました。ここに私のコードがあります: リンクのクリックで JavaScript 関数 GetFBLoginStatus() を呼び出しています。Facebookにログインすると、すべて正常に動作します。Facebook にログインしていない場合、アラートは表示されません。

<div id="fb-root">
</div>

<!-- pull down Facebook's Javascript SDK -->
<script src="http://connect.facebook.net/en_US/all.js"></script>

<script>
    // initialize the library with your Facebook API key
    FB.init({ apiKey: 'XXXXXXXXXXXXX' });
</script>

<div>
<a href="#" onclick="GetFBLoginStatus()"><img src="../FacebookSmall.bmp" /></a>
</div>

<script type="text/javascript" language="javascript">
    function GetFBLoginStatus() 
{
          FB.Event.subscribe('auth.authResponseChange', function(response){                 
        alert(response.status);
        });

        FB.getLoginStatus(function(response) 
{
         alert("inside call back function");

        if (response.status === 'connected')                     
        {   
    var uid = response.authResponse.userID;
           var accessToken = response.authResponse.accessToken;                
           alert("Connected FBID = " + uid);
        } 
        else if (response.status === 'not_authorized') 
 { 
   alert("not_authorized"); 
 } 
       else 
{
  alert("Not Logged into facebook");    
}

     }, true) ;      
  }

于 2012-07-03T13:06:58.087 に答える