使用MessageDigest生成MD5的问题
来源:互联网 发布:js定义一个json数组 编辑:程序博客网 时间:2024/05/20 23:59
之前在工作中需要使用MD5来判断APK是否是同一个文件,开始服务端和客户端使用MD5的方式是没有问题的,但是随着APK文件越来越多,有一天忽然发现同一个APK客户端和服务端计算的MD5值不相同,导致一些问题,二客户端一直采用如下的方式计算.
BigInteger bigInt = new BigInteger(1, digest.digest()); bigInt.toString(16);
这种方式来计算,后来通过验证发现,大部分时间这种方式是没问题的,但是当遇到第一位数字是0时,就会发现得到的MD5把首位的0丢掉啦(很隐蔽的一个坑呀),原因是bigint进行16进制转换的时候第一个0被自动去掉了。
所以不建议使用这种方式来计算一个文件的MD5,可以使用下面的方式:
public class Mdutil { 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); } public static void main(String[] args) { getFileMD5("path"); }}
希望同学们不要踩到这个坑里头。
1 0
- 使用MessageDigest生成MD5的问题
- java.security.MessageDigest的使用,MD5加密!
- 使用MessageDigest 完成MD5加密
- 使用MessageDigest来实现MD5
- java.security.MessageDigest的使用,MD5,安全密令
- [JAVA] 生成MD5 java.security.MessageDigest BUG
- MD5例子 使用java.security.MessageDigest
- JAVA实现MD5加密算法(使用MessageDigest)
- MD5例子 使用java.security.MessageDigest
- JAVA实现MD5加密算法(使用MessageDigest)
- JAVA实现MD5加密算法(使用MessageDigest)
- java.security.MessageDigest的使用(2),生成安全令牌!
- java.security.MessageDigest的使用(2),生成安全令牌!
- MessageDigest类的使用
- MessageDigest 类的用法(MD5加密)
- 【Android数据加密与完整性校验之使用MessageDigest类进行MD5/SHA1】MessageDigest类对文件或字符串生成加密摘要进行完整性校验(一)
- 【Android数据加密与完整性校验之使用MessageDigest类进行MD5/SHA1】MessageDigest类对文件或字符串生成加密摘要进行完整性校验(三)
- MessageDigest 使用注意,并发问题
- Apache Spark探秘:实现Map-side Join和Reduce-side Join
- LayoutAnimal 的简单用法
- Android 6.0中的新技术总结
- 读取data/data/ccc.apl(忘了出处)
- 进程、线程及多进程多线程简介
- 使用MessageDigest生成MD5的问题
- 支撑万亿级访问的微博后端是怎么炼成的
- CUDA 和opencv安装问题
- Binary Tree Level Order Traversal
- jQuery .tmpl(), .template()学习
- React Native第一个Demo(1)
- Java中的隐藏和覆盖
- Python 字典详解
- OPENSSL X509证书验证