无法获得md5哈希

时间:2014-02-13 14:24:33

标签: linux ssl openssl md5

我无法使用OpenSSL获取md5哈希。我使用以下命令进行构建:

gcc -Wall test_3.c -o test_3 -lcrypto -lssl

但是收到以下链接错误:

undefined reference to `MD5Init'
undefined reference to `MD5Update'
undefined reference to `MD5Final'
collect2: ld returned 1 exit status

该计划如下:

#include<stdio.h>
#include<string.h>
#include <openssl/hmac.h>
#include <openssl/md5.h>

int main()
{
  char    digest[17];
  char input[] = "asdfljiahfbqhebfjcnajclgfeliuaef";
  int length = strlen(input);

  MD5_CTX md5;

  MD5Init(&md5);
  MD5Update(&md5,input, length);
  MD5Final(digest,&md5);
  printf("digest  is %s \n",digest);

  return 0;
}

如果您知道问题,请告诉我。请帮帮我

2 个答案:

答案 0 :(得分:3)

你犯了一些错误,我已经纠正了。我还添加了哈希的十六进制输出。否则会破坏你的终端。

#include <stdio.h>
#include <string.h>
#include <openssl/hmac.h>
#include <openssl/md5.h>

int main()
{
    // use unsigned char
    unsigned char    digest[16];
    char *input = "hek2mgl";
    int length = strlen(input);
    int i=0;

    // don't miss the underscore after MD5
    MD5_CTX md5;    
    MD5_Init(&md5);

    while (length > 0) {
        if (length > 512) {
            MD5_Update(&md5, input, 512);
        } else {
            MD5_Update(&md5, input, length);
        }
        length -= 512;
        input += 512;
    }

    MD5_Final(digest, &md5);
    printf("digest is: ");
    for(i = 0; i < 16; i++) {
        printf("%02x", digest[i]);
    }
    printf("\n");
    return 0;
}

输出:

digest is: 1ff8a3b2958ee3340ed88a2b980a8099

答案 1 :(得分:3)

除了hek2mgl的回答之外,OpenSSL wiki还在EVP Message Digests提供了以下示例。

建议使用EVP_*接口,特别是那些不熟悉OpenSSL的一些功能和怪癖的人(这可能是一件好事)。而不是EVP_sha256(),只需使用EVP_md5()

void digest_message(unsigned char *message, unsigned char **digest, unsigned int *digest_len)
{
    EVP_MD_CTX *mdctx;

    if((mdctx = EVP_MD_CTX_create()) == NULL)
        handleErrors();

    if(1 != EVP_DigestInit_ex(mdctx, EVP_sha256(), NULL))
        handleErrors();

    if(1 != EVP_DigestUpdate(mdctx, message, strlen(message)))
        handleErrors();

    if((*digest = (unsigned char *)OPENSSL_malloc(EVP_MD_size(EVP_sha256()))) == NULL)
        handleErrors();

    if(1 != EVP_DigestFinal_ex(mdctx, *digest, digest_len))
        handleErrors();

    EVP_MD_CTX_destroy(mdctx);
}