Android获取apk签名指纹的md5值(防⽌重新被打包)的
实现⽅法
本⽂实例讲述了Android获取apk签名指纹的md5值以防⽌重新被打包的实现⽅法。分享给⼤家供⼤家参考,具体如下:
android获取真正的签名做个记录(这⾥只是Java层的签名校验,java层容易被破解,我建议apk加固下)
获取md5值来进⾏Apk签名校验,可以防⽌apk重新被打包。
下⾯我说说怎么获取apk签名的md5值(有三种⽅法)
1.⽤代码获取签名指纹的md5值
/**
* MD5加密
* @param byteStr 需要加密的内容
* @return 返回 byteStr的md5值
*/
public static String encryptionMD5(byte[] byteStr) {
MessageDigest messageDigest = null;
StringBuffer md5StrBuff = new StringBuffer();
try {
messageDigest = Instance("MD5");
messageDigest.update(byteStr);
byte[] byteArray = messageDigest.digest();
for (int i = 0; i < byteArray.length; i++) {
if (HexString(0xFF & byteArray[i]).length() == 1) {
md5StrBuff.append("0").HexString(0xFF & byteArray[i]));
} else {
md5StrBuff.HexString(0xFF & byteArray[i]));
}
}
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
String();
}
/**
* 获取app签名md5值
*/
public String getSignMd5Str() {
try {
PackageInfo packageInfo = PackageManager().PackageName(), PackageManager.GET_SIGNATURES);    Signature[] signs = packageInfo.signatures;
Signature sign = signs[0];
String signStr = ByteArray());
return signStr;
} catch (PackageManager.NameNotFoundException e) {
e.printStackTrace();
}
return "";
}
2. keytool⼯具
使⽤keytool⼯具获取签名md5信息,下⾯ key是签名⽂件
复制代码代码如下:
C:\Program Files\Java\jdk1.8.0_05\bin>keytool -list -v -keystore C:\Users\Administrator\Desktop\key
3. Eclipse ⾥⾯可以查看签名信息这⾥就不赘述
更多关于Android相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》、《》、《》、《》及《》希望本⽂所述对⼤家Android程序设计有所帮助。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。