在这里插一小节加密的吧,使用openssl库进行加密。
使用MD5加密
我们以一个字符串为例,新建一个文件filename.txt,在文件内写入hello ,然后在Linux下可以使用命令md5sum filename.txt计算md5值 ==> b1946ac92492d2347c6235b4d2611184 。虽然写入的是hello这5个字符,但是我们使用命令xxd filename.txt后可以看出文件结尾处会有个0x0a这个回车符。所以在下面的代码中才会有\n。
//打开/usr/include/openssl/md5.h这个文件我们可以看到一些函数
// 初始化 MD5 Contex, 成功返回1,失败返回0
int MD5_Init(MD5_CTX *c);
// 循环调用此函数,可以将不同的数据加在一起计算MD5,成功返回1,失败返回0
int MD5_Update(MD5_CTX *c, const void *data, size_t len);
// 输出MD5结果数据,成功返回1,失败返回0
int MD5_Final(unsigned char *md, MD5_CTX *c);
// MD5_Init,MD5_Update,MD5_Final三个函数的组合,直接计算出MD5的值
unsigned char *MD5(const unsigned char *d, size_t n, unsigned char *md);
// 内部函数,不需要调用
void MD5_Transform(MD5_CTX *c, const unsigned char *b);
新建一个cpp文件用于计算MD5值
#include <openssl/md5.h>
#include <string.h>
#include <stdio.h> int main()
{
MD5_CTX ctx;
unsigned char outmd[];
int i=; memset(outmd,,sizeof(outmd));
MD5_Init(&ctx);
MD5_Update(&ctx,"hel",);
MD5_Update(&ctx,"lo\n",);
MD5_Final(outmd,&ctx);
for(i=;i<;i<i++)
{
printf("%02X",outmd[i]);
}
printf("\n");
return ;
}
编译选项为: g++ MD5test.cpp -lssl -o MD5test
运行后的结果为: B1946AC92492D2347C6235B4D2611184
注意这里用到openssl库,可以运行 yum install openssl 和 yum install openssl-devel 进行安装。
下面这个代码是对文件进行MD5计算。
#include <openssl/md5.h>
#include <string.h>
#include <stdio.h> int main()
{
MD5_CTX ctx;
unsigned char outmd[];
char buffer[];
char filename[];
int len=;
int i;
FILE * fp=NULL;
memset(outmd,,sizeof(outmd));
memset(filename,,sizeof(filename));
memset(buffer,,sizeof(buffer));
printf("请输入文件名,用于计算MD5值:");
scanf("%s",filename);
fp=fopen(filename,"rb");
if(fp==NULL)
{
printf("Can't open file\n");
return ;
} MD5_Init(&ctx);
while((len=fread(buffer,,,fp))>)
{
MD5_Update(&ctx,buffer,len);
memset(buffer,,sizeof(buffer));
}
MD5_Final(outmd,&ctx); for(i=;i<;i<i++)
{
printf("%02X",outmd[i]);
}
printf("\n");
return ;
}
运行得到结果后,我们可以使用md5sum命令进行验证。
使用SHA1加密
openssl里几个函数讲解
//SHA1算法是对MD5算法的升级,计算结果为20字节(160位),使用方法如下:
//打开/usr/include/openssl/sha.h这个文件我们可以看到一些函数
// 初始化 SHA Contex, 成功返回1,失败返回0
int SHA_Init(SHA_CTX *c);
// 循环调用此函数,可以将不同的数据加在一起计算SHA1,成功返回1,失败返回0
int SHA_Update(SHA_CTX *c, const void *data, size_t len);
// 输出SHA1结果数据,成功返回1,失败返回0
int SHA_Final(unsigned char *md, SHA_CTX *c);
// SHA_Init,SHA_Update,SHA_Final三个函数的组合,直接计算出SHA1的值
unsigned char *SHA(const unsigned char *d, size_t n, unsigned char *md);
// 内部函数,不需要调用
void SHA_Transform(SHA_CTX *c, const unsigned char *data); //上面的SHA可以改为SHA1,SHA224,SHA256,SHA384,SHA512就可以实现多种加密了
我们对上面的程序进行修改
#include <openssl/sha.h>
#include <string.h>
#include <stdio.h> int main()
{
SHA_CTX stx;
unsigned char outmd[];//注意这里的字符个数为20
char buffer[];
char filename[];
int len=;
int i;
FILE * fp=NULL;
memset(outmd,,sizeof(outmd));
memset(filename,,sizeof(filename));
memset(buffer,,sizeof(buffer));
printf("请输入文件名,用于计算SHA1值:");
scanf("%s",filename);
fp=fopen(filename,"rb");
if(fp==NULL)
{
printf("Can't open file\n");
return ;
} SHA1_Init(&stx);
while((len=fread(buffer,,,fp))>)
{
SHA1_Update(&stx,buffer,len);
memset(buffer,,sizeof(buffer));
}
SHA1_Final(outmd,&stx); for(i=;i<;i<i++)
{
printf("%02X",outmd[i]);
}
printf("\n");
return ;
}
MD5有128bit(16个char)*SHA1有160bit(20个char)*SHA256有256bit(32个char)*SHA244有244bit(28个char)*SHA512有512bit(64个char).所以要注意修改大小哦:-O