用C哈希文件内容的正确方法是什么?我不是要对整个文件进行哈希处理,而是要逐行对文件进行哈希处理。我的主要目标是创建一个搜索哈希冲突的程序。我已经用C语言编写了程序,但是它使用系统命令来用MD5和SHA256哈希每一行。我知道使用system命令是不安全的,而且不是执行此操作的正确方法,因此我正在与社区联系,以获取使用MD5和SHA256进行哈希处理的正确方法。
使用OpenSSL C API
#include <openssl/md5.h>
#include <openssl/sha.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void main() {
unsigned char sha256_digest[SHA256_DIGEST_LENGTH];
unsigned char md5_digest[MD5_DIGEST_LENGTH];
unsigned char *buffer = "Hello World!";
int i;
SHA256(buffer, strlen(buffer), sha256_digest);
MD5(buffer, strlen(buffer), md5_digest);
for (i = 0; i < 20; i++) {
printf("%02x", sha256_digest[i]);
}
printf("\n");
for (i = 0; i < 20; i++) {
printf("%02x", md5_digest[i]);
}
}
要编译此代码,您需要使用crypto
库正确链接它
gcc testmd5.c -lcrypto
一旦执行,您将获得此输出
7f83b1657ff1fc53b92dc18148a1d65dfc2d4b1f
ed076287532e86365e841e92bfc50d8c7f83b165