Ответ 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 или где хотите.