static const unsigned char key[] = {
0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77,
0x88, 0x99, 0xaa, 0xbb, 0xcc, 0xdd, 0xee, 0xff,
0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
};
int main()
{
unsigned char text[]="hello world!";
unsigned char * enc_out = malloc(80*sizeof(char));
unsigned char * dec_out = malloc(80*sizeof(char));
AES_KEY enc_key, dec_key;
AES_set_encrypt_key(key, 128, &enc_key);
AES_encrypt(text, enc_out, &enc_key);
AES_set_decrypt_key(key,128,&dec_key);
AES_decrypt(enc_out, dec_out, &dec_key);
int i;
printf("original:\t");
for(i=0;*(text+i)!=0x00;i++)
printf("%X ",*(text+i));
printf("\nencrypted:\t");
for(i=0;*(enc_out+i)!=0x00;i++)
printf("%X ",*(enc_out+i));
printf("\ndecrypted:\t");
for(i=0;*(dec_out+i)!=0x00;i++)
printf("%X ",*(dec_out+i));
printf("\n");
free(enc_out);
free(dec_out);
return 0;
}
注意点:
1. 在解密数据之前,需要调用AES_set_decrypt_key()。
2. 加密的数据不能用print %s打印,因为加密数据不再是由ASCII字符组成了。
本文详细介绍了如何使用AES算法对文本数据进行加密和解密,并通过实例展示了加密前后数据的变化,帮助理解加密过程及效果。
305

被折叠的 条评论
为什么被折叠?



