我的应用程序执行以下操作:
1.询问friends_online_presence权限
2.如果用户授予了权限(即回调表示成功),我会立即测试权限(*),并根据结果提取用户的详细信息(调用getOnlineFriends)。
问题是facebook需要几毫秒来更新其服务器上的权限。因此,当我立即查询权限时,我刚刚要求facebook总是说我没有权限。 使用setTimout“解决”问题。 如何解决这个问题呢? 我尝试了一些原始形式的轮询,但它让浏览器卡住了(这似乎也是一个弯曲的解决方案)。
(*)'SELECT friends_online_presence FROM permissions WHERE uid = me()'
代码:
c2p.facebook = {
requestViewOnlineFriendsPerms: function (callback) {
myStuff.requestPermission('friends_online_presence', callback);
},
requestPermission: function (perms, callback) {
FB.ui({
method: 'permissions.request',
perms: perms,
display: 'popup'
}, function (response) {
if (response && response.perms) {
if (callback) {
callback(true);
}
} else if (!response.perms) {
if (callback) {
callback(false);
}
}
});
fql: function (q, callback) {
FB.api({ "method": "fql.query", "query": q }, callback);
},
getOnlineFriends: function (callback) {
var q = 'SELECT friends_online_presence FROM permissions WHERE uid=me()';
c2p.facebook.fql(q, function (rows) {
var isPermissionGranted = true;
var q2 = "SELECT uid, name, pic_square, online_presence FROM user WHERE online_presence IN ('active', 'idle') AND uid IN (SELECT uid2 FROM friend WHERE uid1 = me()) ORDER BY name";
if (rows[0].friends_online_presence == 0) {
isPermissionGranted = false;
q2 = "SELECT uid, name, pic_square FROM user WHERE uid IN(SELECT uid2 FROM friend WHERE uid1=me()) ORDER BY name";
}
c2p.facebook.fql(q2, function (arr) {
callback(arr, isPermissionGranted);
});
});
}
}
// The way I call this code is:
c2p.facebook.getOnlineFriends(function (arr, isPermissionGranted) {
$("#tmplFriends").tmpl(arr, { getIndex: function () { return $.inArray(this.data, arr); } }).appendTo("#friendsDiv");
if (!isPermissionGranted) {
$('.c2p_hidden').show();
}
});
答案 0 :(得分:1)
c2p.facebook.fql(q2,function(arr){...}如何看到回调变量?它很疯狂。 回调是getOnlineFriends函数的局部变量。
答案 1 :(得分:0)
Tom只是将您的FQL查询放在
中if (response && response.perms) {
}
例如假设我想通过fql获取用户详细信息,我所做的是:
function onloginCall(){
FB.login(handleSessionResponse,{perms:'email,read_stream,publish_stream,offline_access'});
}
function handleSessionResponse(response){
// if we dont have a session, just hide the user info
if (!response.session) {
return;
}
else{
FB.api({
method: 'fql.query',
query: 'SELECT name, pic_square , email FROM user WHERE uid=' + FB.getSession().uid
},
function(response) {
var user = response[0];
store_fbuser_data(FB.getSession().uid,user.name,user.pic_square,user.email) ;
}
);
}
}
我想这会解决你的延迟问题。因为此查询仅在您具有足够权限时才会执行。