由于项目中用到了高德地图,创建应用的时候需要填写SHA1 debug版的时候需要测试 所以 也需要填写debug版的SHA1 但是一开始用命令获取到的是release的 踩了些坑....
查看debug版本的SHA1:
D:\software\jdk\bin\keytool -v -list -keystore C:\Users\Administrator\.android\debug.keystore
分别是 jdk bin目录 + keytool -v -list -keystore + debug.keystore的路径(一般在C:\Users\Administrator\.android目录)
默认密码是: android
如果密码正确,则会出现:
查看release版本的SHA1:
D:\software\jdk\bin\keytool -v -list -keystore C:\Users\Administrator\.android\release.jks (这里可能是.keystore或.jks)
密码是你创建keystore时候填写的密码
验证 release 版本的SHA1的方法:
public static String sHA1(Context context) {
try {
PackageInfo info = context.getPackageManager().getPackageInfo(
context.getPackageName(), PackageManager.GET_SIGNATURES);
byte[] cert = info.signatures[0].toByteArray();
MessageDigest md = MessageDigest.getInstance("SHA1");
byte[] publicKey = md.digest(cert);
StringBuffer hexString = new StringBuffer();
for (int i = 0; i < publicKey.length; i++) {
String appendString = Integer.toHexString(0xFF & publicKey[i])
.toUpperCase(Locale.US);
if (appendString.length() == 1)
hexString.append("0");
hexString.append(appendString);
hexString.append(":");
}
String result = hexString.toString();
return result.substring(0, result.length()-1);
} catch (PackageManager.NameNotFoundException e) {
e.printStackTrace();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return null;
}
打印返回的SHA1 对比 上面命令生成的release版的 SHA1 如果一致说明SHA1值没问题