openssl之EVP系列之9---EVP_Digest系列函数的一个例子

王朝other·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

openssl之EVP系列之9---EVP_Digest系列函数的一个例子

---根据openssl doc\crypto\EVP_DigestInit.pod翻译

(作者:DragonKing, Mail: wzhah@263.net ,发布于:http://openssl.126.com 之openssl专业论坛,版本:openssl-0.9.7)

本例子是openssl帮助文档提供的。该例子根据命令行输入的信息摘要算法名字对"Test Message\n"和"Hello World\n"字符串进行信息摘要操作。

#include <stdio.h>

#include <openssl/evp.h>

main(int argc, char *argv[])

{

EVP_MD_CTX mdctx;

const EVP_MD *md;

char mess1[] = "Test Message\n";

char mess2[] = "Hello World\n";

unsigned char md_value[EVP_MAX_MD_SIZE];

int md_len, i;

//使EVP_Digest系列函数支持所有有效的信息摘要算法

OpenSSL_add_all_digests();

if(!argv[1]) {

printf("Usage: mdtest digestname\n");

exit(1);

}

//根据输入的信息摘要函数的名字得到相应的EVP_MD算法结构

md = EVP_get_digestbyname(argv[1]);

if(!md) {

printf("Unknown message digest %s\n", argv[1]);

exit(1);

}

//初始化信息摘要结构mdctx,这在调用EVP_DigestInit_ex函数的时候是必须的。

EVP_MD_CTX_init(&mdctx);

//使用md的算法结构设置mdctx结构,impl为NULL,即使用缺省实现的算法(openssl本身提供的信息摘要算法)

EVP_DigestInit_ex(&mdctx, md, NULL);

//开始真正进行信息摘要运算,可以多次调用该函数,处理更多的数据,这里只调用了两次

EVP_DigestUpdate(&mdctx, mess1, strlen(mess1));

EVP_DigestUpdate(&mdctx, mess2, strlen(mess2));

//完成信息摘要计算过程,将完成的摘要信息存储在md_value里面,长度信息存储在md_len里面

EVP_DigestFinal_ex(&mdctx, md_value, &md_len);

//使用该函数释放mdctx占用的资源,如果使用_ex系列函数,这是必须调用的。

EVP_MD_CTX_cleanup(&mdctx);

printf("Digest is: ");

for(i = 0; i < md_len; i++) printf("%02x", md_value[i]);

printf("\n");

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航