• Java 文件完整性校验 MD5 sha1 sha256 sha224 sha384 sha512


    由于项目中需要使用文件做备份,并且要提供备份文件的下载功能。备份文件体积较大,为确保下载后的文件与原文件一致,需要提供文件完整性校验。

    网上有这么多此类文章,其中不少使用到了

    org.apache.commons.codec.digest.DigestUtils

    包中的方法,但是又自己做了大文件的拆分及获取相应校验码的转换。

    DigestUtils 包已经提供了为文件流生成校验码的功能,可以直接调用。经测试10几G的文件在30秒内可完成计算。

    (网上提供的一些自己拆分大文件的示例,文件较小时结果正确,文件较大时结果就不太可靠了)

    实现步骤如下:

    1. pom.xml 添加依赖
      <dependency>
          <groupId>commons-codec</groupId>
          <artifactId>commons-codec</artifactId>
          <version>1.12</version>
      </dependency>
    2. 实现类:
      package file.integrity.check;
      
      import org.apache.commons.codec.digest.DigestUtils;
      import java.io.File;
      import java.io.FileInputStream;
      
      public class Application {
          public static void main(String[] args) throws Exception {
              File file = new File("/path/filename");
              FileInputStream fileInputStream = new FileInputStream(file);
              String hex = DigestUtils.sha512Hex(fileInputStream);
              System.out.println(hex);
          }
      }
    3.  或者:
      import org.apache.commons.codec.digest.DigestUtils;
      import static org.apache.commons.codec.digest.MessageDigestAlgorithms.SHA_512;
      import java.io.File;
      
      public class Application {
          public static void main(String[] args) throws Exception {
              File file = new File("/path/filename");
              String hex = new DigestUtils(SHA_512).digestAsHex(file);
              System.out.println(hex);
          }
      }
  • 相关阅读:
    嵌入式Qt4.7.1安装详解
    oracle数据库、客户端安装以及ps/sql连接和导入表实例
    大战C100K之-Linux内核调优篇--转载
    读<阿里亿级日活网关通道架构演进>有感
    hadoop跑第一个实例过程
    Using the command line to manage files on HDFS--转载
    hadoop命令帮助
    从netty-example分析Netty组件续
    windows下spark开发环境配置
    源码分析netty服务器创建过程vs java nio服务器创建
  • 原文地址:https://www.cnblogs.com/matchless/p/10922860.html
Copyright © 2020-2023  润新知