Google хеш-ключ подписи приложения Google Play

Я выбрал подписку на приложение для Google Play, и я понимаю, что Google изменяет ключи подписи для приложения, и я нашел сертификат Sha 1, но не смог найти keyhash.

Как я могу получить keyhash моего выпущенного приложения, есть ли способ извлечь его из сертификата?

Ответ 1

Вы можете извлечь keyhash из сигнатуры сертификата Sha1. Ключевые хеши обычно извлекаются следующим образом:

public static String getKeyHash(final Context context) {
    PackageInfo packageInfo = getPackageInfo(context, PackageManager.GET_SIGNATURES);
    if (packageInfo == null)
        return null;

    for (Signature signature : packageInfo.signatures) {
        try {
            MessageDigest md = MessageDigest.getInstance("SHA");
            md.update(signature.toByteArray());
            return Base64.encodeToString(md.digest(), Base64.NO_WRAP);
        } catch (NoSuchAlgorithmException e) {
            Log.w(TAG, "Unable to get MessageDigest. signature=" + signature, e);
        }
    }
    return null;
}

Вы можете видеть, что версия сигнатуры SHA-1 кодируется Base64.

В меню "Подписание приложений" в консоли разработчика Google Play вы увидите подпись сертификата Sha-1, которая выглядит следующим образом:

SHA1: 3B:DA:A0:5B:4F:35:71:02:4E:27:22:B9:AC:B2:77:2F:9D:A9:9B:D9

В принципе, вам нужно изменить это в байтовый массив, а Base64 - на байтовый массив. Вы можете сделать что-то вроде:

byte[] sha1 = {
    0x3B, (byte)0xDA, (byte)0xA0, 0x5B, 0x4F, 0x35, 0x71, 0x02, 0x4E, 0x27, 0x22, (byte)0xB9, (byte)0xAc, (byte)0xB2, 0x77, 0x2F, (byte)0x9D, (byte)0xA9, (byte)0x9B, (byte)0xD9
};
Log.e("keyhash", Base64.encodeToString(sha1, Base64.NO_WRAP));

Вы можете зарегистрировать эту клавиатуру в настройках входа в facebook android или где хотите.

Ответ 2

Вы можете преобразовать хеш SHA-1 в шестнадцатеричном формате (как показано в Play Play) в хэш хэш base64, используя следующую команду:

echo 33:4E:48:84:19:50:3A:1F:63:A6:0F:F6:A1:C2:31:E5:01:38:55:2E | xxd -r -p | openssl base64

Вывод:

M05IhBlQOh9jpg/2ocIx5QE4VS4=

Этот хэш может использоваться, например, при настройке приложения Facebook.

Ответ 3

Самый простой способ - скопировать сообщение об ошибке Facebook и скопировать ключ, который они ожидали получить оттуда.

Просто убедитесь, что вы используете загруженное приложение Google Play :) enter image description here

Ответ 5

Недавно нашел это приложение Hasher, которое помогает извлекать хеш-код из sha1 (из консоли Google Play Store) и наоборот.