openssl的AES解密算法的EVP_DecryptFinal_ex(&ctx,out+outl,&outltmp);的使用

时间:2023-01-21 19:09:08
#include<stdio.h>
#include<string.h>
#include<windows.h>
#include<openssl/evp.h>
#include<openssl/x509.h>
#pragma comment(lib, "libeay32.lib") 
#define BUFSIZE 128
void tEVP_Encrpyt()
{
unsigned char key[EVP_MAX_KEY_LENGTH]; //密钥
unsigned char iv[EVP_MAX_IV_LENGTH];  // 初始化向量
EVP_CIPHER_CTX ctx; 
//EVP算法上下文
int outl;
int outltmp;
int rv;
int i;
unsigned char out[BUFSIZE];  // 输出密文缓冲区
unsigned char in[BUFSIZE];
const unsigned char *buffer;
buffer=(unsigned char *)malloc(sizeof(in));
memset(in,NULL,sizeof(in));
memset(out,NULL,sizeof(out));
//unsigned char *out;
printf("请输入明文");
scanf("%s",in);
//const unsigned char *msg="Hello OpenSSL";
//设置key 和iv (可采用随机数,也可以由用户输入)
/*for(i=0;i<24;i++)
{
key[i]=i;
}*/
printf("请输入密钥:");
scanf("%s",key);
for(i=0;i<8;i++)
{
iv[i]=i;
}
//初始化密码算法结构体
EVP_CIPHER_CTX_init(&ctx);
//设置算法和密钥以及初始化向量
//rv= EVP_EncryptInit_ex(&ctx,EVP_aes_128_cbc(),NULL,key,iv);
rv= EVP_DecryptInit_ex(&ctx,EVP_aes_128_cbc(),NULL,key,iv);
if(rv!=1)
{
printf("Err\n");
return ;
}
//数据加密
//rv=EVP_EncryptUpdate(&ctx,out,&outl,in,strlen(in));
rv=EVP_DecryptUpdate(&ctx,out,&outl,in,strlen(in));
if(rv!=1)
{
printf("Err\n");
return;
}
//结束数据加密,把剩余数据输出
//rv=EVP_EncryptFinal_ex(&ctx,out+outl,&outltmp);
rv=EVP_DecryptFinal_ex(&ctx,out+outl,&outltmp);
if(rv!=1)
{
printf("Err\n");
return;
}
outl=outl+outltmp;
printf("原文为:%s\n",in);
//打印输出密文
printf("密文长度:%d\n密文数据:\n",outl);

for(i=0;i<outl;i++)
{
printf("0X%02x ",out[i]);
}
}
EVP_DecryptFinal_ex(&ctx,out+outl,&outltmp);这个函数的返回值一直是0,不知道到底是哪里出错了,可是加密的时候就按这个模式的写的就能运行,这是为什么呢

6 个解决方案

#1


将那个evp_decryptfinal_ex函数注释掉试试

#2


man EVP_DecryptFinal_ex

#3


我也遇到了。。

#4


楼主颤一下outl的值,应该是16的倍数,所以没有padding,所以final函数可加密的padding,所以outltmp值为0

#5


那这个怎么处理,一旦遇上16的倍数,后面的块就解密不出来了?

引用 4 楼 hhh_yang 的回复:
楼主颤一下outl的值,应该是16的倍数,所以没有padding,所以final函数可加密的padding,所以outltmp值为0
这个

#6


楼主,问题解决了吗?

#1


将那个evp_decryptfinal_ex函数注释掉试试

#2


man EVP_DecryptFinal_ex

#3


我也遇到了。。

#4


楼主颤一下outl的值,应该是16的倍数,所以没有padding,所以final函数可加密的padding,所以outltmp值为0

#5


那这个怎么处理,一旦遇上16的倍数,后面的块就解密不出来了?

引用 4 楼 hhh_yang 的回复:
楼主颤一下outl的值,应该是16的倍数,所以没有padding,所以final函数可加密的padding,所以outltmp值为0
这个

#6


楼主,问题解决了吗?