【发布时间】:2013-06-29 17:15:45
【问题描述】:
有没有办法从签名的 APK 中获取密钥哈希?
我们有一个签名的 Android apk 文件,我们想找出这个 APK 的密钥哈希,用于 Facebook SDK。
我们可以通过 jarsigner 之类的方法来做到这一点吗?
有什么建议吗?
【问题讨论】:
-
尝试检查this答案
有没有办法从签名的 APK 中获取密钥哈希?
我们有一个签名的 Android apk 文件,我们想找出这个 APK 的密钥哈希,用于 Facebook SDK。
我们可以通过 jarsigner 之类的方法来做到这一点吗?
有什么建议吗?
【问题讨论】:
在 linux 上,我使用此命令从 apk 中获取密钥哈希:
keytool -list -printcert -jarfile [path_to_your_apk] | grep -Po "(?<=SHA1:) .*" | xxd -r -p | openssl base64
对于 Mac 用户 (OS X),因为没有 grep -P 支持
keytool -list -printcert -jarfile ~/Downloads/YOURAPKFILE.apk | grep "SHA1: " | cut -d " " -f 3 | xxd -r -p | openssl base64
【讨论】:
keytool -list -printcert -jarfile ~/Downloads/YOURAPKFILE.apk | grep "SHA1: " | cut -d " " -f 3 | xxd -r -p | openssl base64
keytool -list -printcert -jarfile ~/Downloads/YOURAPKFILE.apk | grep "SHA1: " | cut -d " " -f 3 | xxd -r -p | openssl base64 正是我想要的。谢谢
对于从 openssl 获取密钥的 Windows 用户,有时可能会很棘手。我总是使用它来找到正确的 签名.. 只需将此代码粘贴到您的 onCreate() 中并运行。
// Add code to print out the key hash
try {
PackageInfo info = getPackageManager().getPackageInfo(getPackageName(), PackageManager.GET_SIGNATURES);
for (Signature signature : info.signatures) {
MessageDigest md = MessageDigest.getInstance("SHA");
md.update(signature.toByteArray());
Log.e("MY KEY HASH:", Base64.encodeToString(md.digest(), Base64.DEFAULT));
}
} catch (NameNotFoundException e) {
} catch (NoSuchAlgorithmException e) {
}
更新:
使用安卓工作室(2.1.2):
这将运行一个 gradle 任务,该任务将使用 md5 和 sha1 密钥打印调试和发布证书
【讨论】:
Variant: release Config: none,知道为什么吗?
您可以从here下载openssa
运行以下命令以生成您的密钥哈希。生成时 hashkey 它应该问你密码。
keytool -exportcert -alias androiddebugkey -keystore "C:\Users\Anhsirk.android\debug.keystore" | openssl sha1 -binary | openssl base64
注意:在上面的代码中,请注意您需要提供您的用户路径(即在我的情况下它是 C:\Users\Anhsirk,您只需为您的用户更改此路径帐户。
将密码设置为 android。如果它不要求输入密码,则您的密钥库路径不正确。
【讨论】:
现在回答为时已晚,但它是获取签名应用密钥哈希的非常快速的方法。
安装apk,它可以提取所有应用程序的密钥哈希。
【讨论】:
当我构建我的 Facebook 应用程序时。我使用了我的 Android 密钥库。有一个哈希函数。常用在 Google API 中。(参见那里的说明)。如果您拥有该应用程序并对其进行了签名;否则这应该没问题..你基本上搞砸了。没有办法。
【讨论】:
您还可以使用以下方法从您的 apk 签名密钥库文件中获取 base64 中的 Sha1 Hash(根据 facebook 的要求):-
Mac: keytool -exportcert -alias <KEY_STORE_ALIAS> -keystore <KEY_STORE_PATH> | openssl sha1 -binary | openssl base64
Windows: keytool -exportcert -alias <KEY_STORE_ALIAS> -keystore <KEY_STORE_PATH> | openssl sha1 -binary | openssl base64
您还需要为该命令安装 openssl。
例如:
keytool.exe -list -v -keystore "%LocalAppData%\Xamarin\Mono for Android\debug.keystore" -alias androiddebugkey -storepass android -keypass android | openssl sha1 -binary | openssl base64
其中,"%LocalAppData%\Xamarin\Mono for Android\debug.keystore" 应替换为用于签署 apk 的密钥库文件的路径(在调试或临时分发中)。
【讨论】: