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

yfy21g 2013-11-19 10:35:21
#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,不知道到底是哪里出错了,可是加密的时候就按这个模式的写的就能运行,这是为什么呢
...全文
1716 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
yangduboy 2015-08-01
  • 打赏
  • 举报
回复
楼主,问题解决了吗?
yangduboy 2015-08-01
  • 打赏
  • 举报
回复
那这个怎么处理,一旦遇上16的倍数,后面的块就解密不出来了?
引用 4 楼 hhh_yang 的回复:
楼主颤一下outl的值,应该是16的倍数,所以没有padding,所以final函数可加密的padding,所以outltmp值为0
这个
hhh_yang 2014-11-16
  • 打赏
  • 举报
回复
楼主颤一下outl的值,应该是16的倍数,所以没有padding,所以final函数可加密的padding,所以outltmp值为0
小神仙儿 2014-08-20
  • 打赏
  • 举报
回复
我也遇到了。。
ForestDB 2014-07-15
  • 打赏
  • 举报
回复
man EVP_DecryptFinal_ex
Michael--Lee 2014-07-15
  • 打赏
  • 举报
回复
将那个evp_decryptfinal_ex函数注释掉试试

69,369

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧