在我的一个应用程序中,我需要从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");
}
我通过在MainApplication.onCreate中添加以下内容来修复这个问题:
try {
PackageInfo info = getPackageManager().getPackageInfo(
"com.genolingo.genolingo",
PackageManager.GET_SIGNATURES);
for (Signature signature : info.signatures) {
MessageDigest md = MessageDigest.getInstance("SHA");
md.update(signature.toByteArray());
String hash = Base64.encodeToString(md.digest(), Base64.DEFAULT);
KeyHash.addKeyHash(hash);
}
}
catch (PackageManager.NameNotFoundException e) {
Log.e("PackageInfoError:", "NameNotFoundException");
}
catch (NoSuchAlgorithmException e) {
Log.e("PackageInfoError:", "NoSuchAlgorithmException");
}
然后我将其上传到谷歌开发人员控制台,然后下载了派生的APK,无论出于什么原因,它具有完全不同的键散列。
然后我使用LogCat来确定新的密钥散列,并将其添加到Facebook,就像其他用户所概述的那样。
尽管这个问题已经回答了很多有用的方法,我只是想补充说,当我遵循Rafal Maleks的答案(使用谷歌Play Console上的散列键),我无法使用应用程序签名SHA1密钥,仍然从Facebook得到了一般错误。相反,我需要使用来自上传证书部分的SHA-1证书指纹(就在谷歌Play Console的应用程序签名部分的下面)。否则,同样的过程;
从谷歌播放控制台的“上传证书”中拷贝SHA-1证书指纹
使用:http://tomeko.net/online_tools/hex_to_base64.php转换SHA-1并复制输出(base64)
将其粘贴到developer.facebook.com上的Key Hashes输入中并保存更改。
希望这个答案不是多余的,并将帮助那些不能让它与应用程序签名证书一起工作的人。
现在Facebook登录工作在我的应用程序在调试和发布模式。
我也有同样的问题。我确信这是由于非常小的错误,是的,它是!
我找到了解决方案:
当在我的计算机中生成调试哈希键时,我输入了我的系统密码。但密码应该是-
输入keystore密码:“android”。
这是我唯一的问题。
-----用于生成调试键哈希,使用此命令-
keytool -exportcert -alias androiddebugkey -keystore ~/.android/debug.keystore | openssl sha1 -binary | openssl base64
输入密钥库密码:'android'
-----要生成释放密钥哈希,使用命令-
keytool -exportcert -alias "alias of keystore" -keystore "Your path to the keystore when signing app" | openssl sha1 -binary | openssl base64
执行此命令后,提供您的密钥存储库密码。