学习一下,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
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。