java 计算 文件 md5

public class MD5Check { /** * 默认的密码字符串组合,用来将字节转换成 16 进制表示的字符,apache校验下载的文件的正确性用的就是默认的这个组合 */     protected char hexDigits[] = { ‘0‘, ‘1‘, ‘2‘, ‘3‘, ‘4‘, ‘5‘, ‘6‘, ‘7‘, ‘8‘, ‘9‘, ‘a‘, ‘b‘, ‘c‘, ‘d‘, ‘e‘, ‘f‘ };     protected  MessageDigest messagedigest = null;

{         try {             messagedigest = MessageDigest.getInstance("MD5");         } catch (NoSuchAlgorithmException e) {             e.printStackTrace();         }     }     public String getFileMD5String(File file) throws IOException {         InputStream fis;         fis = new FileInputStream(file);         byte[] buffer = new byte[1024];         int numRead = 0;         while ((numRead = fis.read(buffer)) > 0) {             messagedigest.update(buffer, 0, numRead);         }         fis.close();         return bufferToHex(messagedigest.digest());     }

public String getFileMD5String(InputStream in) throws IOException {         byte[] buffer = new byte[1024];         int numRead = 0;         while ((numRead = in.read(buffer)) > 0) {             messagedigest.update(buffer, 0, numRead);         }         in.close();         return bufferToHex(messagedigest.digest());     }     private String bufferToHex(byte bytes[]) {         return bufferToHex(bytes, 0, bytes.length);     }     private 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 void appendHexPair(byte bt, StringBuffer stringbuffer) {         char c0 = hexDigits[(bt & 0xf0) >> 4];// 取字节中高 4 位的数字转换         // 为逻辑右移,将符号位一起右移,此处未发现两种符号有何不同         char c1 = hexDigits[bt & 0xf];// 取字节中低 4 位的数字转换         stringbuffer.append(c0);         stringbuffer.append(c1);     } }

时间: 2024-10-21 18:53:05

java 计算 文件 md5的相关文章

Java计算文件MD5值代码

原文:http://www.open-open.com/code/view/1424930488031 import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.nio.MappedByteBuffer; import java.nio.channels.FileChannel; import java.security.MessageDigest; import ja

【转】Java计算文件的hash值

原文地址:http://blog.csdn.net/qq_25646191/article/details/78863110 如何知道一个文件是否改变了呢?当然是用比较文件hash值的方法,文件hash又叫文件签名,文件中哪怕一个bit位被改变了,文件hash就会不同. 比较常用的文件hash算法有MD5和SHA-1.我用的是MD5算法,java中,计算MD5可以用MessageDigest这个类. 下面是代码: [java] view plain copy package com.test;

javascript 计算文件MD5 浏览器 javascript读取文件内容

原则上说,浏览器是一个不安全的环境.早期浏览器的内容是静态的,用户上网冲浪,一般就是拉取网页查看.后来,随着互联网的发展,浏览器提供了非常丰富的用户交互功能.从早期的表单交互,到现在的websocket实时通信,乃至html5的流行. html5给前段开发带来了许多有力的工具,以前浏览器大多通过flash插件进行文件的上传和下载,现在我们可以利用html5给我们带来的fileReader api,读取用户通过表单选中的文件内容. fileReader详情请移步: https://develope

Java 获取 文件md5校验码

讯雷下载的核心思想是校验文件的md5值,两个文件若md5相同则为同一文件. 当得到用户下载某个文件的请求后它根据数据库中保留的文件md5比对出拥有此文件的url, 将用户请求挂接到此url上并仿造一个虚假的断点续传请求,从若干url上将一个正常文件拼接出来. 查了下资料,java也可以实现文件md5校验码获取,代码如下: import java.io.File;import java.io.FileInputStream;import java.io.IOException;import jav

Windows下计算文件MD5和SHA256等摘要的方法(利用PowerShell)

有时候需要检验下载文件的md5或sha256的值,之前我一直利用软件计算.最近发现系统自带的Windows PowerShell也可以计算. I) 进入PowerShell: 按Win键+R打开“运行",输入"powershell"并运行之. II)  如图所示: 利用Get-FileHash命令及-Algorithm参数即可计算文件摘要. 原文地址:https://www.cnblogs.com/r0xFED/p/12243537.html

C# 计算文件MD5

因工作需要对文件进行是否被修改判断,整理的一段生成文件MD5码的代码: 1: public class FileHelper 2: { 3: /// <summary> 4: /// 对文件流进行MD5加密 5: /// </summary> 6: public static string MD5Stream(Stream stream) 7: { 8: MD5CryptoServiceProvider md5 = new MD5CryptoServiceProvider(); 9

java计算文件32位md5值

1 protected static String getFileMD5(String fileName) 2 { 3 File file = new File(fileName); 4 if(!file.exists() || !file.isFile()){ 5 return ""; 6 } 7 8 byte[] buffer = new byte[2048]; 9 try { 10 MessageDigest digest = MessageDigest.getInstance(

Python计算文件MD5值

1 import hashlib 2 def fileMD5(filename): 3 m = hashlib.md5() #md5计算 4 #m = hashlib.sha1() #sha1计算 5 #m = hashlib.sha224() #sha224计算 6 #m = hashlib.sha256() #sha256计算 7 #m = hashlib.sha384() #sha384计算 8 #m = hashlib.sha512() #sha512计算 9 # 10 with ope

计算文件或一段内容的md5值

// 计算text内容MD5 QByteArray gAppTextChecksum(const QString& text) { QCryptographicHash crypto(QCryptographicHash::Md5); crypto.addData(text.toLocal8Bit()); return crypto.result().toHex(); } // 计算文件MD5 QByteArray gAppFileChecksum(const QString& fileP