2012-07-31 82 views
1

我成功地將FBConnect集成到我的應用程序中。連接和註冊頁面正常工作。Facebook連接集成不再工作

但是自從有一段時間,當我點擊facebook按鈕時,我綁定的事件不再被提起。

<script src="http://connect.facebook.net/fr_FR/all.js" ></script> 
<script type="text/javascript"> 
//console integration 
if(typeof console !== 'object') 
console = {}; 
if((typeof console.debug) !== 'function'){ 
    if(typeof opera === 'object'){ 
     console = { 
      debug : function(){return opera.postError(arguments);}, 
      info : function(){this.debug('[INFO] ',arguments);}, 
      log : function(){this.debug('[LOG] ',arguments);} 
     }; 
    } 
    else{ 
     console = { 
      debug : function(){return true;}, 
      info : function(){return true;}, 
      log : function(){return true;} 
     }; 
    } 
} 

/** 
* Fonction called to init and manage FB Connection 
*/ 
handleFacebook(); 
$('#fb-button').click(function(){ 
    alert('ok'); 
    fbGetLoginStatus(); 
}); 

/** 
* 
*/ 
function handleFacebook() { 
    if(!window.fbApiInit) { 
     FB.init({appId: 'myAppId', xfbml: true, cookie: true}); 
     fbApiInit = true; 
    } 
} 

function fbGetLoginStatus() { 
    FB.getLoginStatus(function(response) { 
     onStatus(response); // once on page load 
     FB.Event.subscribe('auth.statusChange', onStatus); // every status change 
    }); 
} 

/** 
* This will be called once on page load, and every time the status changes. 
*/ 
function onStatus(response) { 
    console.info('onStatus', response); 
    if (response.status == 'connected') { 
     console.info('User logged in'); 
     if (response.perms) { 
      console.info('User granted permissions'); 
     }else{ 
      console.info('User has not granted permissions'); 
     } 
     getAccountInfo(); 
    } else { 
     console.info('User is logged out'); 
    } 
} 

/** 
* This assumes the user is logged out, and renders a login button. 
*/ 
function showLoginButton() { 
    var button = '<fb:login-button perms="email" />'; 
    $('#fb-login-button').html(button); 
    FB.XFBML.parse(document.getElementById('fb-login-button')); 
} 

function getAccountInfo() { 
    FB.api(
     { 
     method: 'fql.query', 
     query: 'SELECT username, first_name, last_name, uid, email, sex FROM user WHERE uid='+FB.getUserID() 
     }, 
     function(response) { 
      console.info('API Callback', response); 
      var user = response[0]; 

      $('#usernamefb').val(user.username); 
      $('#mailfb').val(user.email); 

      $('#facebook-connect-form').submit(); 
     } 
    ); 
} 
</script> 
<div id="fb-login-button"> 
    <fb:login-button perms="email" id="fb-button" /> 
</div> 
<form method="post" action="/facebook-connect" id="facebook-connect-form"> 
    <input type="hidden" id="usernamefb" name="usernamefb"/> 
    <input type="hidden" id="mailfb" name="mailfb"/> 
</form> 

我注意到在$的警報功能( '#FB-按鈕')。單擊事件不會被調用。 這裏沒有顯示,但我包括我的文件中的jQuery庫上。 有什麼想法?

感謝您的回答。

回答

0

Facebook更改了它們的按鈕,並且我沒有找到一種方法將更改後的點擊事件綁定到它。

我將我的網站更改爲訂閱加載的FB事件。 初始化FB時,必須將Option「status」設置爲false以防止初始化時自動執行Loginstatus-Check!

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

      //auth.statusChange 
      FB.Event.subscribe('auth.authResponseChange', function (response) { 
       if (response.status.indexOf('connected') != -1) { 
        // the user is logged in and has authenticated your 
        // app, and response.authResponse supplies 
        // the user's ID, a valid access token, a signed 
        // request, and the time the access token 
        // and signed request each expire 
        var uid = response.authResponse.userID; 
        var accessToken = response.authResponse.accessToken; 

        //Handle the access token 
        jQuery.ajax({ 
         url: 'token_handler.ashx', 
         type: 'POST', 
         data: "accessToken=" + accessToken, 
         success: function (msg) { 

         } 
        }); 

       } else if (response.status.indexOf('not_authorized') != -1) { 
        // the user is logged in to Facebook, 
        // but has not authenticated your app 
       } else { 
        // the user isn't logged in to Facebook. 
       } 
      }); 
     }; 
    (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)); 
}