这里定义了一个转化方法,把文件或文件流以字节的方式进行转换,使之生成唯一的md5,此方法间接的应用到了md5的生成中。
这里主要定义了一个根据提供的文件流输入流InputStream进行生成md5的值,如上几幅图中的代码加在一起就是完整的文件或文件流的md5值生成方法。
4
最后一张图片为最终生成后的效果,文件上传的时候可以先生成md5的值后到数据库中进行查找,如果找到了就说明相同的文件已经存在,那么就不应该再保存了,否则会出现相同的冗余文件。
package cdmimport 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"))
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)