为大于内存的数据生成哈希(不会被捕)

发布于 2024-10-21 12:16:26 字数 477 浏览 3 评论 0原文

溢出们下午好! ;)

我想要做什么:

我对验证传输文件的完整性感兴趣。

我是如何处理它的:

我正在考虑为此使用哈希码,但有一个问题。这些文件可能非常大,因此我需要能够迭代生成哈希值。我无法将整个文件加载到内存中。

到目前为止我看到的内容:

我正在调查murmur3 skein 用于哈希函数。我相信我了解如何使其与 skein 一起使用,但我构建的版本未通过所有已知的结果单元测试。我不知道如何“链接”杂音以获得有效的结果。

有什么建议吗?

Good afternoon Overflowers! ;)

What I want to do:

I'm interested in verifying transferred file integrity.

How I approached it:

I was considering using a hash code for this but there's one problem. The files can be extremely large so I need to be able to iteratively generate the hash. I can't load the entire file into memory.

What I've looked at so far:

I'm investigating murmur3 and skein for the hash function. I believe I understand how to make it work with skein but the version I've built fails all the known result unit tests. I'm not sure how to "chain" murmur to get a valid result.

Any suggestions?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

小草泠泠 2024-10-28 12:16:26

大多数哈希算法对固定大小的数据块进行操作 - 例如,您可以查找 SHA1 或 MD5 参考实现,它们使用“init/loop { update }/finalize”结构,允许您根据需要传递任意多或少的数据每次更新。

例如 Skein,他们在参考实现中使用相同的概念:

int  Skein_256_Init  (Skein_256_Ctxt_t *ctx, size_t hashBitLen);
int  Skein_256_Update(Skein_256_Ctxt_t *ctx, const u08b_t *msg, size_t msgByteCnt);
int  Skein_256_Final (Skein_256_Ctxt_t *ctx, u08b_t * hashVal);

为什么您认为需要将整个数据作为一个块传递?您正在寻找简化的包装函数吗?

Most hash algorithms operate on fixed-size blocks of data - you can e.g. look up SHA1 or MD5 reference implementations, they use an "init/loop { update }/finalize" construct allowing you to pass as much or little data as you wish in every update.

Looking at e.g. Skein, they use the same concept in their reference implementation:

int  Skein_256_Init  (Skein_256_Ctxt_t *ctx, size_t hashBitLen);
int  Skein_256_Update(Skein_256_Ctxt_t *ctx, const u08b_t *msg, size_t msgByteCnt);
int  Skein_256_Final (Skein_256_Ctxt_t *ctx, u08b_t * hashVal);

Why do you think you need to pass the entire data as one block? Are you looking at simplified wrapper functions?

第七度阳光i 2024-10-28 12:16:26

您应该看看 Crypto++。这是我最喜欢的加密 C++ 库。

这里是如何使用它。

You should have a look at Crypto++. It's my favorite cryptographic C++ library.

And here's how you could use it.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文