Java中如何计算文件的MD5与SHA哈希值

来源:站长查询作者:Robin头衔:草根站长
导读:本期聚焦于小伙伴创作的《Java中如何计算文件的MD5与SHA哈希值》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《Java中如何计算文件的MD5与SHA哈希值》有用,将其分享出去将是对创作者最好的鼓励。

在Java开发中,计算文件的MD5与SHA哈希值是验证文件完整性、实现文件去重等场景的常用操作,核心依赖Java内置的MessageDigest类完成哈希计算,无需引入第三方依赖即可实现相关功能。

Java中如何计算文件的MD5与SHA哈希值

核心依赖类介绍

Java的java.security.MessageDigest类提供了消息摘要算法的功能,支持MD5、SHA1、SHA256、SHA512等多种哈希算法,是计算文件哈希值的核心类。使用时需要先通过getInstance方法获取对应算法的实例,再通过update方法传入数据,最后通过digest方法获取哈希结果。

计算文件MD5哈希值实现

计算文件MD5的步骤分为四步:获取MD5算法的MessageDigest实例、读取文件内容并分批次更新到摘要中、计算最终摘要、将字节数组转换为十六进制字符串。以下是完整实现代码:

import java.io.FileInputStream;
import java.io.IOException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

public class FileHashUtil {
    /**
     * 计算文件的MD5哈希值
     * @param filePath 文件路径
     * @return MD5哈希值的十六进制字符串,计算失败返回null
     */
    public static String getFileMD5(String filePath) {
        try (FileInputStream fis = new FileInputStream(filePath)) {
            // 获取MD5算法的MessageDigest实例
            MessageDigest digest = MessageDigest.getInstance("MD5");
            byte[] buffer = new byte[8192];
            int len;
            // 分批次读取文件内容,更新摘要
            while ((len = fis.read(buffer)) != -1) {
                digest.update(buffer, 0, len);
            }
            // 计算最终摘要
            byte[] hashBytes = digest.digest();
            // 将字节数组转换为十六进制字符串
            return bytesToHex(hashBytes);
        } catch (IOException | NoSuchAlgorithmException e) {
            e.printStackTrace();
            return null;
        }
    }

    /**
     * 字节数组转十六进制字符串
     * @param bytes 字节数组
     * @return 十六进制字符串
     */
    private static String bytesToHex(byte[] bytes) {
        StringBuilder hexString = new StringBuilder();
        for (byte b : bytes) {
            // 将字节转换为无符号整数,再格式化为两位十六进制
            String hex = Integer.toHexString(0xff & b);
            if (hex.length() == 1) {
                hexString.append('0');
            }
            hexString.append(hex);
        }
        return hexString.toString();
    }
}

计算文件SHA哈希值实现

SHA系列哈希算法的实现逻辑和MD5基本一致,仅需要在获取MessageDigest实例时传入对应的算法名称即可,常见的SHA算法包括SHA1、SHA256、SHA512,以下是通用实现方法:

import java.io.FileInputStream;
import java.io.IOException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

public class FileHashUtil {
    /**
     * 计算文件的SHA哈希值
     * @param filePath 文件路径
     * @param algorithm 哈希算法,如SHA-1、SHA-256、SHA-512
     * @return 哈希值的十六进制字符串,计算失败返回null
     */
    public static String getFileSHA(String filePath, String algorithm) {
        try (FileInputStream fis = new FileInputStream(filePath)) {
            // 获取对应SHA算法的MessageDigest实例
            MessageDigest digest = MessageDigest.getInstance(algorithm);
            byte[] buffer = new byte[8192];
            int len;
            while ((len = fis.read(buffer)) != -1) {
                digest.update(buffer, 0, len);
            }
            byte[] hashBytes = digest.digest();
            return bytesToHex(hashBytes);
        } catch (IOException | NoSuchAlgorithmException e) {
            e.printStackTrace();
            return null;
        }
    }

    /**
     * 字节数组转十六进制字符串
     * @param bytes 字节数组
     * @return 十六进制字符串
     */
    private static String bytesToHex(byte[] bytes) {
        StringBuilder hexString = new StringBuilder();
        for (byte b : bytes) {
            String hex = Integer.toHexString(0xff & b);
            if (hex.length() == 1) {
                hexString.append('0');
            }
            hexString.append(hex);
        }
        return hexString.toString();
    }
}

不同哈希算法对比

不同的哈希算法在安全性和性能上存在差异,开发者可以根据实际需求选择:

算法名称哈希长度(位)安全性适用场景
MD5128较低,已被证明存在碰撞漏洞非安全场景的文件完整性校验、简单去重
SHA1160中等,存在理论碰撞可能一般场景的文件校验
SHA256256较高,目前无已知有效攻击安全敏感场景的文件校验、数字签名
SHA512512对安全性要求极高的场景

使用示例

调用上述方法计算文件哈希值的示例如下:

public class Test {
    public static void main(String[] args) {
        String filePath = "D:/test.txt";
        // 计算文件MD5
        String md5 = FileHashUtil.getFileMD5(filePath);
        System.out.println("文件MD5:" + md5);
        // 计算文件SHA256
        String sha256 = FileHashUtil.getFileSHA(filePath, "SHA-256");
        System.out.println("文件SHA256:" + sha256);
        // 计算文件SHA1
        String sha1 = FileHashUtil.getFileSHA(filePath, "SHA-1");
        System.out.println("文件SHA1:" + sha1);
    }
}

注意事项

  • 读取大文件时建议使用缓冲区分批次读取,避免一次性将文件加载到内存导致内存溢出,上述代码中使用8192字节的缓冲区是通用选择。
  • 计算哈希值前需要确认文件存在且有读取权限,否则会抛出IO异常。
  • 如果用于安全场景,不建议使用MD5和SHA1算法,优先选择SHA256及以上长度的算法。
  • 转换十六进制字符串时需要注意补位,保证每个字节对应两位十六进制字符,避免结果错误。

JavaMD5SHA文件哈希MessageDigest修改时间:2026-06-14 11:54:36

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。