我的问题类似于this one here,但我使用的是openssl / md5.h
我正在尝试获取用户输入并找到其MD5哈希值。这是我的代码:
#include <stdio.h>
#include <openssl/md5.h>
#include <stdlib.h>
#include <string.h>
void MD5hash(unsigned char *data, unsigned int dataLen, unsigned char *digest) {
MD5_CTX c;
MD5_Init(&c);
MD5_Update(&c, data, dataLen);
MD5_Final(digest, &c);
}
int main(){
unsigned char md5_hash[MD5_DIGEST_LENGTH];
char *input = NULL;
int i, read;
size_t len;
printf("Enter the password: ");
read = getline(&input, &len, stdin);
unsigned int str_length = (unsigned int)strlen(input);
if(-1 != read)
puts(input);
else
printf("Received no input\n");
printf("Size read: %d Len: %zu String Length: %u\n", read, len, str_length);
MD5hash((unsigned char *)input, str_length, md5_hash);
printf("MD5 hash is: ");
for(i = 0; i < MD5_DIGEST_LENGTH; i++){
printf("%02x", md5_hash[i]);
}
printf("\n");
free(input);
return 0;
}
此代码可以在Mac上编译并成功运行。当我将12345
作为二进制文件的输入时,得到的输出为d577273ff885c3f84dadb8578bb41399
:
$ ./md5code
Enter the password: 12345
12345
Size read: 6 Len: 8
String Length: 6
MD5 hash is: d577273ff885c3f84dadb8578bb41399
但是,当我运行md5 -s 12345
时,我得到的输出是827ccb0eea8a706c4c34a16891f84e7b
,这也是我使用在线工具检查MD5时得到的输出。
我最初的想法是这是由于NULL终止符,所以我用它们来计算字符串的MD5:
$ md5 -s 12345
MD5 ("12345") = 827ccb0eea8a706c4c34a16891f84e7b
$md5 -s "12345\0"
MD5 ("12345\0") = b04fd4a8d62d25c4b69616ba7f5c5092
$md5 -s 12345\0
MD5 ("123450") = 149787a6b7986f31b3dcc0e4e857cd2a
$md5 -s "12345 "
MD5 ("12345 ") = 43d6757765116456c1c49310cbf8070d
$ md5 -s "12345\n"
MD5 ("12345\n") = 5d44fc965c76c70d2ebe72b4129bc0cd
您可以看到,没有任何MD5与我从代码中获得的MD5相匹配。谁能帮助我找出问题所在以及如何解决?谢谢!
注意:我很清楚MD5是一个非常脆弱且散乱的哈希,不应将其用于任何实际目的。我这样做只是为了了解基本编码。