0

我们正在使用我们的 android 应用程序 Facebook SDK 版本 3.0.1 对于 Facebook 登录,我使用了本教程: https ://developers.facebook.com/docs/howtos/androidsdk/3.0/login-with-facebook/

我的许多用户在使用 Facebook 登录进入我们的应用程序时遇到问题。用户不断向我发送有关此问题的电子邮件,我也可以在他们的日志中看到他们无法进入。单击 Facebook LoginButton 后,它会转到 Facebook LoginActivity,显示进度条并永远停留在那里。我没有从 Facebook 得到任何答复,也没有任何异常,除非用户单击后退按钮。

我已经从 Facebook 的 SDK 打印了一些日志,所以也许有人会理解为什么会出现这个问题。

记录事件

这是一个可以正常工作的日志流示例

在此处输入图像描述

这是我的代码:

我的活动:


/**My Activity **/
//BackClickListenerActivity extends FragmentActivity
public class RegisterActivity extends BackClickListenerActivity implements RegistrationManager{

        private RegistrationFragment mainFragment;

        @Override
        public void onCreate(Bundle savedInstanceState) {

            super.onCreate(savedInstanceState);    
            setContentView(R.layout.register);

            if (savedInstanceState == null) {
                // Add the fragment on initial activity setup
                mainFragment = new RegistrationFragment();
                getSupportFragmentManager()
                .beginTransaction()
                .add(android.R.id.content, mainFragment)
                .commit();
            } else {
                // Or set the fragment from restored state info
                mainFragment = (RegistrationFragment) getSupportFragmentManager()
                        .findFragmentById(android.R.id.content);
            }
            ...
        }

        public void onStart() {     
            mainFragment.initialize(this,R.layout.register,false);
            super.onStart();
        }

        @Override
        protected void onActivityResult(int requestCode, int resultCode, Intent data) {
            super.onActivityResult(requestCode, resultCode, data);
            switch (requestCode) {

            case REQUEST_FACEBOOK_LOGIN:
                if (resultCode == RESULT_OK) {
                    ...
                } 
                else {
                    ...
                }
                ...
            }
        }

}

我的片段:

   public class RegistrationFragment extends Fragment{

        public void initialize(RegistrationManager registrationManager, int layoutRes, boolean hideButton){

            this.registrationManager = registrationManager;
            sentRequest = false;
                    // I use this fragment from 2 different Activities, and 2 layouts
            this.layoutRes = layoutRes;

        }


    @Override
    public View onCreateView(LayoutInflater inflater, 
            ViewGroup container, 
            Bundle savedInstanceState) {
        Log.d(TAG,"onCreateView RegistrationManager");
        final View view = inflater.inflate(layoutRes, container, false);

        LoginButton authButton = (LoginButton) view.findViewById(R.id.facebook_login);

        authButton.setFragment(this);
        authButton.setReadPermissions(Arrays.asList(FacebookConfig.getInstance().getPermissions()));
        ...
    }

    @Override
    public void onCreate(Bundle savedInstanceState) {
        Log.d(TAG,"onCreate RegistrationManager");
        super.onCreate(savedInstanceState);
        uiHelper = new UiLifecycleHelper(getActivity(), callback);
        uiHelper.onCreate(savedInstanceState);
    }
    private void onSessionStateChange(Session session, SessionState state, Exception exception) {

        if(state == SessionState.OPENING){
            ...
        }
        else if (state.isOpened()) {
            ...

        } else if (state.isClosed()) {
            ...

        }
    }
    private Session.StatusCallback callback = new Session.StatusCallback() {
        @Override
        public void call(Session session, SessionState state, Exception exception) {
            onSessionStateChange(session, state, exception);
        }
    };
    @Override
    public void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
        uiHelper.onActivityResult(requestCode, resultCode, data);
    }
    @Override
    public void onResume() {
        super.onResume();
        uiHelper.onResume();
    }
    @Override
    public void onPause() {
        super.onPause();
        uiHelper.onPause();
    }

    @Override
    public void onStop(){
        super.onStop();
    }
    @Override
    public void onDestroy() {
        super.onDestroy();
        uiHelper.onDestroy();
    }

    @Override
    public void onSaveInstanceState(Bundle outState) {
        super.onSaveInstanceState(outState);
        uiHelper.onSaveInstanceState(outState);
    }

}

在 SDK 中,我做了一些处理 LoginButton 的更改 - 我更改了图像、文本并在 onClick 侦听器的注释下放置会话不为空的情况(以防止注销)。希望我的问题足够清楚,有人可以帮助我们。谢谢你,亚历克斯

4

2 回答 2

2

我也有同样的问题。在设备 2.3.4 或更低版本中,默认登录无法按预期工作。对于所有这些设备,我必须实现 Web Dialog。完成后从对话框中获取访问令牌并从该访问令牌设置会话。到目前为止,它似乎正在工作。

Bundle bundle = new Bundle();
bundle.putString("message", "message");
WebDialog localWebDialog = new WebDialog.Builder(this, "app_id", "oauth", bundle).build();
localWebDialog.setOnCompleteListener(new WebDialog.OnCompleteListener()
{
    public void onComplete(Bundle bundle, FacebookException facebookException)
    {

        Session.getActiveSession();
        AccessToken localAccessToken = AccessToken.createFromExistingAccessToken(bundle.getString("access_token"), null, null, AccessTokenSource.WEB_VIEW, null);
        Session.openActiveSessionWithAccessToken(MainActivity.this.getApplicationContext(), localAccessToken, MainActivity.this.callback);
    }
});
localWebDialog.show();

private class SessionStatusCallback implements Session.StatusCallback {
    @Override
    public void call(Session session, SessionState state, Exception exception) {
        if(session.isOpened()
            //do something
    }
于 2013-06-06T19:39:30.520 回答
1

我无法添加评论,所以请不要对此投反对票:)。

为了 Facebook,您不会收到异常,但通常会收到警告/日志输出,您可以在其中看到登录过程中发生的情况。如果您遇到 keyhash 问题,那么您肯定会收到警告异常。

请检查您的 logcat 以获取提示。

一个很好的示例是这个Hackbook

于 2013-06-02T22:12:30.870 回答