android app內動態獲取apk簽名md5,與keytool獲取的一致
阿新 • • 發佈:2019-02-04
首先使用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命令列獲取的一模一樣。