我得到的结果是相同类型的文件返回相同的md5哈希值。例如两个不同的jpgs给了我相同的结果。然而,一个JPG和一个apk会给出不同的结果。从URL获取MD5哈希文件
这里是我的代码...
public static String checkHashURL(String input) {
try {
MessageDigest md = MessageDigest.getInstance("MD5");
InputStream is = new URL(input).openStream();
try {
is = new DigestInputStream(is, md);
int b;
while ((b = is.read()) > 0) {
;
}
} finally {
is.close();
}
byte[] digest = md.digest();
StringBuffer sb = new StringBuffer();
for (int i = 0; i < digest.length; i++) {
sb.append(
Integer.toString((digest[i] & 0xff) + 0x100, 16).substring(
1));
}
return sb.toString();
} catch (Exception ex) {
throw new RuntimeException(ex);
}
}
你确定是哈希jpg文件,而不是404错误与DNS未发现错误? –
我的猜测是只有文件数据的标题标记正在读取和散列,因此导致类似类型的文件看起来相同。我建议调试正在读取的数据。 – Vulcan