在我的一个应用程序中,我需要从Facebook获取数据…我是这样做的:

我已经创建了应用ID。它成功登录,但注销后,我登录,然后它给我:

我做错了什么?我正在使用Facebook SDK…我已经在手机上安装了Facebook。它在模拟器中运行良好,但没有安装内置的Facebook应用程序。

这是我的代码:

if (FB_APP_ID == null) {
    Builder alertBuilder = new Builder(this);
    alertBuilder.setTitle("Warning");
    alertBuilder.setMessage("A Facebook Applicaton ID must be " +
                            "specified before running this example: see App.java");
    alertBuilder.create().show();
}

// Initialize the dispatcher
Dispatcher dispatcher = new Dispatcher(this);
dispatcher.addHandler("login", LoginHandler.class);
dispatcher.addHandler("stream", StreamHandler.class);
dispatcher.addHandler("logout", LogoutHandler.class);

// If a session already exists, render the stream page
// immediately. Otherwise, render the login page.
Session session = Session.restore(this);
if (session != null) {
    dispatcher.runHandler("stream");
}
else {
    dispatcher.runHandler("login");
}

当前回答

我是这样解决这个问题的:

首先,您必须获得SHA-1值。有两种方法。

在Android Studio中获取SHA-1值。

点击它 点击签署报告 复制SHA-1的值

OR

从密钥存储文件中获取SHA-1值。

keytool -list -v -keystore keystore_file_name.jks -alias key0

复制SHA-1值到你的剪贴板,像这样:

CD:A1:EA:A3:5C:5C:68:FB:FA:0A:6B:E5:5A:72:64:DD:26:8D:44:84

并打开十六进制-> Base64字符串解码器将您的SHA-1值转换为Base64。

这正是Facebook所需要的。

获取生成的哈希值“********************=”,并将密钥哈希值复制到Facebook应用程序。

其他回答

如果您正在生成释放密钥散列,请确保输入密钥库的实际密码,而不是“android”。

这是我的问题。调试版本正在工作,但是发布APK没有。

我也遇到过同样的问题。我对这种奇怪行为的可能原因做了一个简短的研究,我发现了以下几点:

在一个新的Facebook应用程序的第一次执行期间,即使你没有指定任何键哈希,它也将允许连接/登录。 对我来说,Facebook提供的教程没有生成正确的键散列,因为它给出了错误的配置。当执行: keytool -exportcert -alias androiddebugkey -keystore % home路径%\.android\调试。Keystore | openssl sha1 -binary | openssl . Keystore | openssl sha1 -binary | openssl . Keystore base64

确保检查了所有属性——HOMEPATH、密钥库的存在等等。可能还需要提供密码。

生成正确配置的是@Mahendran建议的解决方案。 此外,如果您看到最初发布的错误(http://i.stack.imgur.com/58q3v.png),那么您在屏幕上看到的键散列很可能就是您的真实键散列。如果其他方法都不管用,试试把它输入Facebook。

我得到了所有这些结果:Windows 7 64位版本,Android Studio 1.2.2, JDK 7。

我也有同样的问题。首先登录,没问题,但接下来,一个无效的键散列。

Unity的Facebook SDK得到了错误的键散列。它从"C:\Users\ your user".android\debug获取键。密钥存储库”,在理想情况下,它应该从您在项目中创建的密钥存储库中获取。这就是为什么它告诉你键哈希没有注册。

正如Madi所建议的,您可以按照此链接上的步骤找到正确的键。只需确保将它们指向项目中的密钥库。否则你就拿不到正确的钥匙。

经过长时间的研究,我们找到了解决办法。

我们将权限设置为:

loginButton.setReadPermissions(public_profile email);

这是第一次工作,但当我们重新登录Facebook时,它给出了无效的哈希错误。

简单的解决方案是将上面的行更改为:

loginButton.setReadPermissions(Arrays.asList("public_profile", "email"));

它的工作就像一种幸福!

Facebook应该返回正确的异常,而不是误导性的无效哈希键错误。

根据Facebook登录Android,你必须提供关键哈希值。为了获得它,您将需要用于签署应用程序的密钥。

keytool \
    -exportcert \
    -alias YourKeyAlias \
    -storepass YourStoreKeyPassword \
    -keystore PathToYourKeyStoreFile | openssl sha1 -binary | openssl base64