【发布时间】:2020-07-14 00:47:12
【问题描述】:
在 C 中散列文件内容的正确方法是什么?我不是要对整个文件进行哈希处理,而是逐行对文件进行哈希处理。我的主要目标是创建一个搜索哈希冲突的程序。我用 C 语言编写了程序,但它使用系统命令用 MD5 和 SHA256 对每一行进行哈希处理。我知道使用系统命令是不安全的,而且不是正确的方法,因此我正在与社区联系以获取使用 MD5 和 SHA256 散列的正确方法。
【问题讨论】:
-
有许多可用的“字符串散列函数”,快速搜索会发现很多,包括
md5和sha256。两个很好的通用哈希表链接是Coding up a Hash Table 和Hash tables - eternally confuzzled。本质上,您想读取/散列每一行。 (一个很好的冲突测试是/usr/share/dict/words文件,它将提供 100,000 到 300,000 个字(每行一个) -
作为一般的“新用户”注意事项——欢迎使用 Stack Overflow。请尽快阅读About 页面并访问描述How to Ask a Question 和How to create a Minimal, Complete, and Verifiable example 的链接。确保您的问题与主题相关,这将有助于其他人提供简洁而不是笼统的答案(并防止投反对票)