import java.io.File
import java.io.FileInputStream
import java.io.FileNotFoundException
import java.io.IOException
import java.math.BigInteger
import java.nio.MappedByteBuffer
import java.nio.channels.FileChannel
import java.security.MessageDigest
import org.apache.commons.codec.digest.*
import org.apache.commons.io.IOUtils
public class testMD5 {
public static String getMd5ByFile(File file) throws FileNotFoundException {
String value = null
FileInputStream in = new FileInputStream(file)
try {
MappedByteBuffer byteBuffer = in.getChannel().map(FileChannel.MapMode.READ_ONLY, 0, file.length())
MessageDigest md5 = MessageDigest.getInstance("MD5")
md5.update(byteBuffer)
BigInteger bi = new BigInteger(1, md5.digest())
value = bi.toString(16)
} catch (Exception e) {
e.printStackTrace()
} finally {
if(null != in) {
try {
in.close()
} catch (IOException e) {
e.printStackTrace()
}
}
}
return value
}
public static void main(String[] args) throws IOException {
String path="E:\文件.zip"
String v = getMd5ByFile(new File(path))
System.out.println("MD5:"+v.toUpperCase())
FileInputStream fis= new FileInputStream(path)
String md5 = DigestUtils.md5Hex(IOUtils.toByteArray(fis))
IOUtils.closeQuietly(fis)
System.out.println("MD5:"+md5)
//System.out.println("MD5:"+DigestUtils.md5Hex("WANGQIUYUN"))
}
}
我使用了部分取值的方式来提高MD5的计算速度,这样的时候,时间主要耗费在了IO中。如果是100K(换成500K也并没有提高执行的速度)取一个字符计算大约10秒以内。但是如果全部读取可能要60秒或者更多。对于大文件建议使用一些文件相关信息和部分文件内容做MD5.比如用文件长度和一定间隔取一些字节。Java中使用MD5算法计算消息摘要时,输入字符串的格式是有影响的。为了得到正确的结果,你需要确保输入字符串的格式符合一定的要求。比如,如果你使用了多余的空格或其他非法字符,那么你得到的消息摘要可能会与预期不符。需要注意的是,不同的编码方式可能会导致相同的字符串在计算消息摘要时得到不同的结果。因此,在使用Java的MD5算法时,你应该确保输入字符串的编码方式与你预期的一致。
总之,在Java中使用MD5算法时,输入字符串的格式是有影响的,你需要注意字符串的格式以及编码方式,以确保得到正确的结果。
回答不易,望请采纳