encode.c
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <errno.h>
#include "openssl/aes.h"
int main()
{
char *p_msq;
int len = 100;
int cnt=0,c;
p_msq = (char *)malloc(len);
while((c = getchar())!='\n')
{
p_msq[cnt++] = c;
if(cnt >= len-1)
{
len+=100;
p_msq=(char *)realloc(p_msq, len);//不够,重新分配内存。
}
}
char user_key[AES_BLOCK_SIZE] = "abc123";
AES_KEY key;
char *e_msq;
AES_set_encrypt_key(user_key, AES_BLOCK_SIZE*8, &key);
AES_encrypt(p_msq, e_msq, &key);
printf("%s\n",e_msq);
/*char *msg;
AES_set_decrypt_key(user_key, 128, &key);
AES_decrypt(e_msq, msg, &key);
printf("%s\n",msg);*/
return 0;
}
decode.c
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <errno.h>
#include "openssl/aes.h"
int main()
{
char *p_msq;
int len = 100;
int cnt=0,c;
p_msq = (char *)malloc(len);
while((c = getchar())!='\n')
{
p_msq[cnt++] = c;
if(cnt >= len-1)
{
len+=100;
p_msq=(char *)realloc(p_msq, len);//不够,重新分配内存。
}
}
char user_key[AES_BLOCK_SIZE] = "abc123";
AES_KEY key;
char *e_msq;
AES_set_encrypt_key(user_key, AES_BLOCK_SIZE*8, &key);
AES_encrypt(p_msq, e_msq, &key);
printf("%s\n",e_msq);
/*char *msg;
AES_set_decrypt_key(user_key, 128, &key);
AES_decrypt(e_msq, msg, &key);
printf("%s\n",msg);*/
return 0;
}
在Ubuntu环境下编译之后,用encode加密aaaaaaaaaa之后得到密文,之后再复制粘贴用decode解密发现仍然是乱码,求大佬帮帮孩子
您好,我是有问必答小助手,你的问题已经有小伙伴为您解答了问题,您看下是否解决了您的问题,可以追评进行沟通哦~
如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~
ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632
非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!
速戳参与调研>>>https://t.csdnimg.cn/Kf0y
C和C++完整教程:https://blog.csdn.net/it_xiangqiang/category_10581430.html
C和C++算法完整教程:https://blog.csdn.net/it_xiangqiang/category_10768339.html
加密后的数据应该是不可逆的吧,根本就不能解密。