请问大佬们为什么我写的AES加密和解密算法在编译为两个可执行文件后解密为乱码

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

加密后的数据应该是不可逆的吧,根本就不能解密。