0

我开发了 facebook 应用程序,但是当它安装到设备上时,如果设备上没有安装 facebook 应用程序,并且当 facebook 应用程序安装时会话无法打开,则它可以正常工作。我的代码如下,

Session.openActiveSession(this, true,
            new Session.StatusCallback() {
                // callback when session changes state
                @Override
                public void call(Session session, SessionState   state,
                        Exception exception) {
                    if (session.isOpened()) {

                        // make request to the /me API
                        Request.executeMeRequestAsync(session,
                                new Request.GraphUserCallback() {
                                    @Override
                                    public void onCompleted(GraphUser user,
                                            Response res) {
                                        if (user != null) {
                                            User.getInstance().setProfile(user);

                                        }
                                    }
                                });
                    }
                }
            });

      @Override
  public void onActivityResult(int requestCode, int resultCode, Intent data) {
      super.onActivityResult(requestCode, resultCode, data);
      Session.getActiveSession().onActivityResult(this, requestCode, resultCode,  data);
      if(Session.getActiveSession().isOpened()) {
          Log.i("here opened", "thnx");

      }
}
4

1 回答 1

2

大家好,我想与您分享此信息,以解决任何面临上述问题的人。

有时当您开发 facebook 应用程序时,您需要通过 keytool 生成哈希密钥“您可以通过此命令生成它 keytool -exportcert -alias androiddebugkey -keystore C:\Users\YOURUSER.android\debug.keystore | "C:\ bin\bin\openssl" sha1 -binary |"C:\bin\bin\openssl" base64 输入 android 作为密码"。

上述方法中的问题有时会生成错误的哈希键,因为它取决于 JDK 版本并使用了 openssl 应用程序,因此您的 facebook 应用程序无法登录。

问题解决了,您可以在活动中编写下面的代码,并使用生成的哈希键代替上面的一个,一切都会正常工作。

    try {
        PackageInfo info = getPackageManager().getPackageInfo(
                "com.kartag.gui", 
                PackageManager.GET_SIGNATURES);
        for (Signature signature : info.signatures) {
            MessageDigest md = MessageDigest.getInstance("SHA");
            md.update(signature.toByteArray());
            Log.d("KeyHash:", Base64.encodeToString(md.digest(), Base64.DEFAULT));
            }
    } catch (NameNotFoundException e) {

    } catch (NoSuchAlgorithmException e) {

    }
于 2013-04-26T13:12:58.673 回答