在 FB.init 之后调用时,FB.api 不起作用

2024-01-25

在 FB.init 之后调用时,FB.api 不起作用。这是我使用的代码片段:

window.fbAsyncInit = function() {
  FB.init({
    appId : window.APP_ID,
    status : true,
    cookie : true,
    oauth : true,
    channelUrl : window.MASTER_URL + "channel",
    frictionlessRequests : true
  });

  window.COMPANY.init();
};

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

这是我的 COMPANY.init() 和 COMPANY.fetchAllFriends():

friends: new Array(),

init : function() {
  // TODO

  COMPANY.fetchAllFriends();

  FB.Canvas.setSize($(document).height());
  FB.Canvas.setAutoGrow();
},    

fetchAllFriends : function() {
  FB.api('/me/friends', function(response) {
    if (!response || response.error) {
      return;
    }

    COMPANY.friends = new Array();
    $.each(response.data, function(index, value) {
      COMPANY.friends.push(value.id);
    });
  });
},

其中 fetchAllFriends 响应包含错误,其中显示“必须使用活动访问令牌来查询有关当前用户的信息。”。我确保(通过浏览器调试器)在调用 FB.api 之前调用 FB.init。

任何帮助将不胜感激!


好的,我解决了我的问题。我变了:

window.fbAsyncInit = function() {
  FB.init({
    appId : window.APP_ID,
    status : true,
    cookie : true,
    oauth : true,
    channelUrl : window.MASTER_URL + "channel",
    frictionlessRequests : true
  });

  window.COMPANY.init();
};

to:

window.fbAsyncInit = function() {
  FB.init({
    appId : window.APP_ID,
    status : true,
    cookie : true,
    oauth : true,
    channelUrl : window.MASTER_URL + "channel",
    frictionlessRequests : true
  });

  FB.Event.subscribe('auth.login', window.COMPANY.init);
};

以防其他人想知道。我发现,当 FB.init 返回时,FB JS SDK 尚未形成用户会话,因此您需要做的是使用 init 函数订阅“auth.login”事件。更多信息here http://developers.facebook.com/docs/reference/javascript/FB.Event.subscribe/

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

在 FB.init 之后调用时,FB.api 不起作用 的相关文章

随机推荐