Facebook Android SDK 3.0回调未被取消取消

时间:2013-01-28 21:49:29

标签: android facebook

我正在尝试使用Facebook Android SDK v3.0升级现有应用/框架,但我仍然坚持如何使用额外权限进行身份验证。

问题是如果用户取消,StatusCallback似乎不会触发。如果我使用常规电话Session.openActiveSession,则会在取消时触发回调,但在新Session.OpenRequest个对象上使用新的Session则不会。

这是我的代码:

Session.OpenRequest auth = new Session.OpenRequest(this);

String[] permissions = {"publish_stream", "user_status"};

auth.setPermissions(Arrays.asList(permissions));

auth.setLoginBehavior(SessionLoginBehavior.SSO_WITH_FALLBACK);

auth.setCallback(new Session.StatusCallback() {
    @Override
    public void call(Session session, SessionState state, Exception exception) {
        switch(state) {

            case OPENING:
                System.out.println("OPENING");
                break;              

            case OPENED: // <-- NOT CALLED
                System.out.println("OPENED");
                break;

            case CREATED: // <-- NOT CALLED
                System.out.println("CREATED");
                break;

            case CREATED_TOKEN_LOADED: // <-- NOT CALLED
                System.out.println("CREATED_TOKEN_LOADED");
                break;

            case OPENED_TOKEN_UPDATED: // <-- NOT CALLED
                System.out.println("OPENED_TOKEN_UPDATED");
                break;

            case CLOSED: // <-- NOT CALLED
                System.out.println("CLOSED");
                break;      

            case CLOSED_LOGIN_FAILED: // <-- NOT CALLED
                System.out.println("CLOSED_LOGIN_FAILED");
                break;                          
        }
    }
});

Session session = new Session.Builder(this).setApplicationId("<My APP ID>").build();
session.openForPublish(auth);

这会在设备上生成如下视图:

http://cl.ly/image/0E2C0t2m2b0g

(未安装FB应用)。如果用户单击关闭按钮(左上角),则不会触发回调。

如果我在同一场景中使用Session.openActiveSession,则会触发回调。

这是一个错误,还是我做错了什么?

谢谢!

1 个答案:

答案 0 :(得分:5)

发现问题。在手动创建会话时,必须将此会话设置为静态Session实例上的“活动会话”:

Session session = new Session.Builder(this).setApplicationId("<My APP ID>").build();
Session.setActiveSession(session); // <-- MUST DO THIS
session.openForPublish(auth);