用户在Facebook Auth Dialogue Javascript SDK中跳过权限

时间:2012-04-26 16:12:55

标签: facebook facebook-graph-api facebook-javascript-sdk facebook-authentication

我在页面标签中有一个使用facebook javascript sdk的应用程序。当新用户访问该应用程序时,我会收到预期的“使用Facebook登录”弹出窗口。我也有一些扩展权限,我已经放在FB.Login的scope参数中。用户使用Facebook登录后,我会看到预期的扩展权限弹出窗口。唯一的问题是,如果用户跳过扩展权限,对话框将返回access_token,但它对扩展权限无效。下面的代码示例。

window.fbAsyncInit = function () {
    FB.Canvas.setAutoGrow();
    FB.init({
        appId: facebookAppId, 
        status: true, // check login status
    });

    function updateFBInfo(response) {
        console.log('updateResp:');
        if (response.authResponse) {
            //user is already logged in and connected
            FB.api('/me', function (info) {
                displayUserInfo(info, response);
            });
        }
        else {
            FB.login(function (loginResponse) {
                if (loginResponse.authResponse) {
                    FB.api('/me', function (info) {
                        displayUserInfo(info, loginResponse);
                    });
                }
            }, { scope: 'email,manage_pages,offline_access,publish_stream' });
        }
    }

    FB.getLoginStatus(updateFBInfo);
};

我想我的问题是,我错过了什么(这必须是简单的事情),还是有办法检查并查看返回的acces_token是否真的有效?

1 个答案:

答案 0 :(得分:9)

在继续之前,您需要明确检查权限。如果他们没有提供必要的权限,则需要再次显示FB.login()所需的范围。

以下是检查权限的代码:

FB.api('/me/permissions', function (response) {
            var perms = response.data[0];
            // Check for publish_stream permission in this case....
            if (perms.publish_stream) {                
                // User has permission
            } else {                
                // User DOESN'T have permission. Perhaps ask for them again with FB.login?
            }                                            
    } );