在工作中需要使用MD5来判断APK是否是同一个文件,发现同一个APK文件和服务端计算的MD5值不相同,导致MD5首位为0自动舍弃问题。
客户端一直采用如下的方式计算.
- BigInteger bigInt = new BigInteger(1, digest.digest());
- bigInt.toString(16);
这种方式来计算,通过验证发现,大部分时间这种方式是没问题的,但是当遇到第一位数字是0时,就会发现得到的MD5把首位的0丢掉,原因是bigint进行16进制转换的时候第一个0被自动去掉了。
所以我们采用如下方式:
public class Md5Utils {
protected static char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6','7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };
public synchronized static String getFileMD5(String path) {
System.out.println(path);
File file = new File(path);
if (!file.exists() || !file.isFile()) {
System.out.println("文件不存在");
return null;
}
MessageDigest digest = null;
FileInputStream fis = null;
try {
digest = MessageDigest.getInstance("MD5");
fis = new FileInputStream(file);
byte[] buffer = new byte[1024];
int numRead = 0;
while ((numRead = fis.read(buffer)) > 0) {
digest.update(buffer, 0, numRead);
}
fis.close();
} catch (Exception e) {
// TODO: handle exception
}
return bufferToHex(digest.digest());
}
private static String bufferToHex(byte bytes[]) {
return bufferToHex(bytes, 0, bytes.length);
}
private static String bufferToHex(byte bytes[], int m, int n) {
StringBuffer stringbuffer = new StringBuffer(2 * n);
int k = m + n;
for (int l = m; l < k; l++) {
appendHexPair(bytes[l], stringbuffer);
}
return stringbuffer.toString();
}
private static void appendHexPair(byte bt, StringBuffer stringbuffer) {
char c0 = hexDigits[(bt & 0xf0) >> 4];
char c1 = hexDigits[bt & 0xf];
stringbuffer.append(c0);
stringbuffer.append(c1);
}
}