OpenSSL 之 MD5

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了OpenSSL 之 MD5相关的知识,希望对你有一定的参考价值。

  学习一下,OpenSSL,使用OpenSSL有两种方式:命令执行和库调用。对于我来说,学习是为了写代码。直奔库调用了。先从最简单的MD5入手吧!

  OpenSSL官网上找到MD5简介只有函数的声明,没有相对明确的解释:

#include <openssl/md5.h>

unsigned char *MD5(const unsigned char *d, unsigned long n,
                 unsigned char *md);

int MD5_Init(MD5_CTX *c);
int MD5_Update(MD5_CTX *c, const void *data,
                 unsigned long len);
int MD5_Final(unsigned char *md, MD5_CTX *c);


  从函数的声明中只有看到,提供了4个函数。翻阅了下代码可大概理解了。上面的MD5函数与下面三个函数(MD5_Init,MD5_Update,MD5_Final)是两种使用方式。上面的MD5函数的内部实现其实也是调用下面的三个函数来完成的。

  MD5函数可以直接获取到对应的MD5值,但需要传的内容为指定的unsigned char类型的数据。这个相对使用场景要可能少一些。下面的MD5_Update则可以传任意类型的地址,这个相对更加适合对普通的文本或数据包来进行计算。


  下面代码是MD5的使用例子:  

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

int main( int argc, char **argv )
{
        unsigned char md[MD5_DIGEST_LENGTH];
        char strMd5[MD5_DIGEST_LENGTH+1];

        const char *data = "hello world!";

        MD5_CTX c;

        if( !MD5_Init(&c) )
        {
                std::cout<<"MD5_Init failed"<<std::endl;
                return -1;
        }

        MD5_Update(&c, data, strlen(data));
        MD5_Final(md, &c);

        for( int nIndex = 0; nIndex < MD5_DIGEST_LENGTH; nIndex ++ )
        {
                sprintf(strMd5+nIndex*2, "%02x\t", md[nIndex]);
        }

        std::cout<<strMd5<<std::endl;

        return 0;
}


  编译链接为:    

g++ -o myMD5 -I /usr/local/openssl/include/ -L /usr/local/openssl/lib/ -lcrypto myMD5.cpp


本文出自 “点滴成长” 博客,请务必保留此出处http://xdataplus.blog.51cto.com/3614757/1956372

以上是关于OpenSSL 之 MD5的主要内容,如果未能解决你的问题,请参考以下文章

使用OpenSSL获取文件的MD5值

Linux环境下使用openssl库的MD5进行数据加密

使用 Crypto 将 PHP openssl_encrypt 与 md5 转换为 NodeJS

从OpenSSL库中分离算法-MD5算法

openssl md5 sha256 rsa des

PHP 将 mcrypt 转换为 openssl