在我的一个应用程序中,我需要从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");
}
生成的哈希键错误。您可以通过两个步骤获得哈希键。
一种是通过命令提示符。另一个是通过编码。通过命令提示符的散列键仅在第一次工作。我不知道原因。我也有同样的问题。所以我试着通过编程来实现。
遵循以下步骤:
将以下代码粘贴到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的更多详细信息,请查看链接。
如果你在设置页面中添加了错误的信息,这意味着它会给出一些错误。所以要使用正确的信息。此外,如果公众(除您之外)需要使用您的应用程序,则意味着您需要启用权限(在设置旁边的“状态和审查”中更改“是”)。
将以下代码粘贴到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) {
e.printStackTrace();
}
catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
只需修改包名。然后转到LogCat文件,在这里选择Debug搜索。然后你会找到哈希键。现在复制这个散列键,然后转到developer。facebook。app_id site,编辑你的散列键,然后按保存。现在再次运行Android项目。我认为问题会得到解决。
我也遇到过同样的问题。我对这种奇怪行为的可能原因做了一个简短的研究,我发现了以下几点:
在一个新的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。
在你的活动的onCreate()方法中使用以下代码:
try {
PackageInfo info = getPackageManager().getPackageInfo(
"your application package name",
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) {
}
运行此代码。这将生成哈希键。在Facebook应用程序设置中复制此KeyHash,并保存更改。然后登录到您的应用程序。这在将来也会非常有效。
如果你遇到了这个问题,把这个键输入到你的developer.facebook.com:
然后确保你的应用在developer.facebook.com上是活跃的。
这个绿色圆圈表示应用程序是活的:
如果不是,那么按照以下两个步骤让你的应用上线:
步骤1进入应用程序→设置→添加“联系邮箱”,选择“保存更改”。
步骤2进入App Review选项,确保该选项为Yes。我加了一张截图:
注意:如果你想复制hashkey,请检查LogCat中的BlueServiceQueue。
我也有同样的问题。我确信这是由于非常小的错误,是的,它是!
我找到了解决方案:
当在我的计算机中生成调试哈希键时,我输入了我的系统密码。但密码应该是-
输入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
执行此命令后,提供您的密钥存储库密码。
Facebook使用的不是用于调试的默认密码和别名。你需要改变它,它会工作。
/usr/lib/jvm/jdk1.8.0_66/bin/keytool -exportcert -alias androiddebugkey -keystore ~/.android/debug.keystore | openssl sha1 -binary | openssl base64
如果你没有修改任何默认密码,它应该是“android”。
您还可以在构建中配置它。gradle文件。但是生成散列时应该使用相同的别名密码:
android {
signingConfigs {
release {
storeFile file("~/.android/debug.keystore")
storePassword "android"
keyAlias "androiddebugkey"
keyPassword "android"
}
}
}
下面的代码将为您提供Facebook的散列,但您必须遵循以下步骤才能获得发布候选散列。
Copy and paste this code in your main activity
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) {
}
Generate a signed APK file.
Connect your phone to a laptop and make sure it stays connected.
Install and run the APK file in your phone by manually moving the release APK to your phone.
Now look at Android LogCat (use filter KeyHash:). You should see your release hash key for Facebook. Simply copy and paste it in your https://developers.facebook.com/apps. It's under settings.
Now you can test the app it should work perfectly well.
您必须创建两个键散列,一个用于调试,另一个用于发布。
对于Debug键哈希:
在OS X上运行:
keytool -exportcert -alias androiddebugkey -keystore ~/.android/debug.keystore | openssl sha1 -binary | openssl base64
在Windows上运行:
keytool -exportcert -alias androiddebugkey -keystore %HOMEPATH%\.android\debug.keystore | openssl sha1 -binary | openssl
base64
调试键哈希源代码
对于Release键哈希:
在OS X上,运行(将<>之间的值替换为您的值):
keytool -exportcert -alias <RELEASE_KEY_ALIAS> -keystore <RELEASE_KEY_PATH> | openssl sha1 -binary | openssl base64
在Windows上,使用(将<>之间的值替换为您的值):
keytool -exportcert -alias <RELEASE_KEY_ALIAS> -keystore <RELEASE_KEY_PATH> | openssl sha1 -binary | openssl base64
释放键哈希源代码
我通过在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,就像其他用户所概述的那样。
我是这样解决这个问题的:
首先,您必须获得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应用程序。
尽管这个问题已经回答了很多有用的方法,我只是想补充说,当我遵循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登录工作在我的应用程序在调试和发布模式。
我看到很多人给出了困难的答案,通过我解决我的问题的答案只是去项目/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
}