在我的一个应用程序中,我需要从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");
}
我看到很多人给出了困难的答案,通过我解决我的问题的答案只是去项目/android文件夹/应用程序使用终端,这是你调试的地方。Keystore文件为
keytool -exportcert -alias androiddebugkey -keystore debug.keystore | openssl sha1 -binary | openssl base64
复制粘贴这个命令,替换你的项目/android/app/build.gradle中的别名和密码
debug {
storeFile file('debug.keystore')
storePassword 'android'
keyAlias 'androiddebugkey' <---- alias
keyPassword 'android' <---- password
}
我是这样解决这个问题的:
首先,您必须获得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应用程序。
我也有同样的问题。我确信这是由于非常小的错误,是的,它是!
我找到了解决方案:
当在我的计算机中生成调试哈希键时,我输入了我的系统密码。但密码应该是-
输入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
执行此命令后,提供您的密钥存储库密码。
生成的哈希键错误。您可以通过两个步骤获得哈希键。
一种是通过命令提示符。另一个是通过编码。通过命令提示符的散列键仅在第一次工作。我不知道原因。我也有同样的问题。所以我试着通过编程来实现。
遵循以下步骤:
将以下代码粘贴到oncreate()中。
try {
PackageInfo info = getPackageManager().getPackageInfo(
"com.example.packagename",
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) {
}
修改com . example。”packagename”与你的包名在上面的编码中没有失败(你可以在Android manifest文件中找到你的包名)。
运行应用程序。转到您粘贴上述代码的活动。在LogCat文件中,搜索“KeyHash”。你可能会找到一个键散列。复制键哈希和去Facebook应用仪表板页面。进入设置并输入如下图所示的详细信息。
完成上述步骤后,再次重新启动应用程序。你现在可以登录Facebook了。
有关key hash的更多详细信息,请查看链接。
如果你在设置页面中添加了错误的信息,这意味着它会给出一些错误。所以要使用正确的信息。此外,如果公众(除您之外)需要使用您的应用程序,则意味着您需要启用权限(在设置旁边的“状态和审查”中更改“是”)。