查看release版SHA1 和debug版的SHA1

由于项目中用到了高德地图,创建应用的时候需要填写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 和debug版的SHA1_第1张图片



查看release版本的SHA1:

D:\software\jdk\bin\keytool -v -list -keystore C:\Users\Administrator\.android\release.jks (这里可能是.keystore或.jks)

密码是你创建keystore时候填写的密码

查看release版SHA1 和debug版的SHA1_第2张图片



验证 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值没问题



你可能感兴趣的:(Android)