方法一:
#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加密的源碼,可以直接使用。