要领一:
#include<stdio.h>
#include<openssl/md5.h>
#include<string.h>
int main( int argc, char **argv )
{
MD5_CTX ctx;
unsigned char *data="123";
unsigned char md[16];
char buf[33]={‘\0’};
char tmp[3]={‘\0’};
int i;
MD5_Init(&ctx);
MD5_Update(&ctx,data,strlen(data));
MD5_Final(md,&ctx);
for( i=0; i<16; i++ ){
sprintf(tmp,"%02X",md[i]);
strcat(buf,tmp);
}
printf("%s\n",buf);
return 0;
}
输出:
202CB962AC59075B964B07152D234B70
要领二:
#include<stdio.h>
#include<openssl/md5.h>
#include<string.h>
int main( int argc, char **argv )
{
unsigned char *data = "123";
unsigned char md[16];
int i;
char tmp[3]={‘\0’},buf[33]={‘\0’};
MD5(data,strlen(data),md);
for (i = 0; i < 16; i++){
sprintf(tmp,"%2.2x",md[i]);
strcat(buf,tmp);
}
printf("%s\n",buf);
return 0;
}
输出:
202cb962ac59075b964b07152d234b70
总结:
两种实现方法,一样的功效。对较量,第二种要领更直观简朴些。
碰着的问题:
1.sprintf时的名目,%02X和%2.2名目是一样的,强制输出两位,好比十进制的8,十六进制也是8,这个名目是节制输出两位,08。假如加密功效要小写字母显示,就是"%2.2x",大写就是"2.2X"。
2.必然要利用unsigned char,固然是char,其实就是个int,虽然,它只有一个字节,和char的区别是,unsigned char 0~255 ,char -127~127。利用char会出问题。这个md5加密函数,返回16个十进制数,范畴在0~255间,把它format为十六进制就是32为md5编码了。
3.gcc编译的时候,后头加上参数 -lcrypto 假如系统没有安装libcrypto,是不能用这个要领的。
假如不想利用openssl库函数,前面我的文章里有md5加密的源码,可以直接利用。