我在java中遇到md5哈希问题。要检查文件更新,我从服务器获取一个列表,并将文件与本地列表进行比较。
使用php中的md5_file()
函数创建服务器文件哈希值。
我的用于计算文件校验和的java代码给出了与异常不同的输出。
一些调试输出可以看出差异:
00000.res:b3359dec77910db596b095be7aa49000
00001.res:84411f08999df4fb6ddab1345d21c72c
00002.res:be305453dd435f4a019a1c7b444aff8b
00003.res:66df5d3462287ba6df7bdaa5c32484f2
00004.res:283d977b128e0e7b07de8d4b867f24c9
00000.res:1f012efee3c2c414512a5f19e5f598dd < server
00001.res:fdb212a9280815d98a67be7fe23408d7 < server
00002.res:64151232cc0e6939a024966e8159151c < server
00003.res:f1c9859d2d1f431b76425b11a6a1090e < server
00004.res:0393da6442a0ec153ded0bb6e7e1085c < server
java函数:
private static final char[] HEX_DIGITS = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'};
public static String getMD5(File file) throws NoSuchAlgorithmException, IOException {
MessageDigest md = MessageDigest.getInstance("MD5");
InputStream is = new FileInputStream(file);
try {
is = new DigestInputStream(is, md);
byte[] buffer = new byte[4 * 1024];
int read;
while ((read = is.read(buffer)) != -1) {
md.update(buffer, 0, read);
}
} finally {
is.close();
}
final byte[] data = md.digest();
final int l = data.length;
final char[] out = new char[l << 1];
for (int i = 0, j = 0; i < l; i++) {
out[j++] = HEX_DIGITS[(0xF0 & data[i]) >>> 4];
out[j++] = HEX_DIGITS[0x0F & data[i]];
}
return new String(out);
}
我尝试用谷歌搜索,但我得到的是字符串的md5哈希。我很确定我的问题必须与md.update()函数有关。我是否以错误的方式复制缓冲区?
答案 0 :(得分:1)
据我所知,您根本不应该致电.update
- DigestInputStream
的全部内容是它会动态更新摘要 你看了。
您只需在结尾处拨打.digest
即可获得最终结果。