1. 程式人生 > >android app內動態獲取apk簽名md5,與keytool獲取的一致

android app內動態獲取apk簽名md5,與keytool獲取的一致

首先使用keytool命令列獲取:
cmd中使用命令列:keytool -list -keystore D:\Desktop\app_key
這裡寫圖片描述
根據提示輸入keystore的密碼,回車就可以看到簽名的md5,sha1,sha256等資訊這裡寫圖片描述
然後在app中使用次keystore編譯app並打log,app程式碼:

/**
     * MD5加密
     * @param byteStr 需要加密的內容
     * @return 返回 byteStr的md5值
     */
    public static String encryptionMD5(byte[] byteStr) {
        MessageDigest messageDigest = null
; StringBuffer md5StrBuff = new StringBuffer(); try { messageDigest = MessageDigest.getInstance("MD5"); messageDigest.reset(); messageDigest.update(byteStr); byte[] byteArray = messageDigest.digest(); // return Base64.encodeToString(byteArray,Base64.NO_WRAP);
for (int i = 0; i < byteArray.length; i++) { if (Integer.toHexString(0xFF & byteArray[i]).length() == 1) { md5StrBuff.append("0").append(Integer.toHexString(0xFF & byteArray[i])); } else { md5StrBuff.append(Integer.toHexString(0xFF
& byteArray[i])); } } } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } return md5StrBuff.toString(); } /** * 獲取app簽名md5值,與“keytool -list -keystore D:\Desktop\app_key”‘keytool -printcert *file D:\Desktop\CERT.RSA’獲取的md5值一樣 */ public String getSignMd5Str() { try { PackageInfo packageInfo = getPackageManager().getPackageInfo( getPackageName(), PackageManager.GET_SIGNATURES); Signature[] signs = packageInfo.signatures; Signature sign = signs[0]; String signStr = encryptionMD5(sign.toByteArray()); return signStr; } catch (PackageManager.NameNotFoundException e) { e.printStackTrace(); } return ""; }

列印結果:
這裡寫圖片描述
可以看到與keytool命令列獲取的一模一樣。