首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >计算目录的SHA-1

计算目录的SHA-1
EN

Stack Overflow用户
提问于 2012-12-13 18:49:28
回答 3查看 1.7K关注 0票数 1

我正在尝试计算整个目录结构的SHA-1校验和。

到目前为止,我所做的是递归地计算每个常规文件的SHA-1,并将所有校验和附加在一起。问题是,这使得计算依赖于遍历文件的顺序

也就是说,如果我有一个包含文件的文件夹

file1.dat file2.dat

另一个文件夹包含相同的文件,但排序方式为

file2.dat file1.dat

这将计算不同的校验和。

如何使SHA-1计算顺序独立?

谢谢!

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-12-13 19:04:54

你至少有两个选择:

  1. 为目录创建存档文件,然后为其创建摘要。( digest.
  2. Pre-order,jar)在创建摘要之前,使用algorithm.
  3. Create将所有文件字节读取到单字节数组中,然后从该数组中创建

数据。

就我个人而言,我会选择第一种,这是快速和简单的。

票数 0
EN

Stack Overflow用户

发布于 2012-12-13 18:56:12

在计算SHA-1之前,尝试对从File.list获得的文件名进行排序,或者对File.listFiles的File[]进行排序,文件是可比较的。Arrays.sort就足够了。请注意,File.list / File.listFile返回的项没有特定的顺序,尽管它们可能看起来是有序的。

票数 2
EN

Stack Overflow用户

发布于 2012-12-13 18:59:07

既然您已经准备好了散列计算算法,那么您只需为每个目录添加一个集合(或任何其他不采用重要元素顺序的数据结构)中的所有散列,然后检查这些集合是否相等

Set Class

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13858223

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档