
C语言使用openssl加密后,文件解密时候的读取总是不能完全读出来?怎么解决 5
怀疑是加密后的文件中有文件结束符,所以再有c读取时就读不完了。怎么解决呢。。。。哪个加密时候遇到这个问题的高手指点一下,解密时这样做的。。EVP_CIPHER_CTXct...
怀疑是加密后的文件中有文件结束符,所以再有c读取时就读不完了。怎么解决呢。。。。哪个加密时候遇到这个问题的高手指点一下,
解密时这样做的。。
EVP_CIPHER_CTX ctx;
FILE *in=NULL, *out=NULL; //
in=fopen("c:\\2.txt","r+");
out=fopen("c:\\3.txt","w+");
int do_encrypt=0;//
// EVP_BytesToKey(EVP_rc2_ecb(),EVP_md5(),NULL,passwd,strlen(passwd),1,key,iv);
unsigned char key[] = "01234567ab";
unsigned char iv[] = "12345678";
// 修改参数
EVP_CIPHER_CTX_init(&ctx);
// EVP_CipherInit_ex(&ctx, EVP_rc2(), NULL, NULL, NULL, do_encrypt);
EVP_CipherInit_ex(&ctx, EVP_rc2_cfb(), NULL, NULL, NULL, do_encrypt);
EVP_CIPHER_CTX_set_key_length(&ctx, 10);
//完成参数设置,进行key和IV的设置
EVP_CipherInit_ex(&ctx, NULL, NULL, key, iv, do_encrypt);
for(;;)
{
inlen = fread(inbuf, 1, 1024, in);
if(inlen <= 0) break;
if(!EVP_CipherUpdate(&ctx, outbuf, &outlen, inbuf, inlen))
{
/*出错处理 */
return 0;
}
fwrite(outbuf, 1, outlen, out);
printf("%d\n",outlen);
} 展开
解密时这样做的。。
EVP_CIPHER_CTX ctx;
FILE *in=NULL, *out=NULL; //
in=fopen("c:\\2.txt","r+");
out=fopen("c:\\3.txt","w+");
int do_encrypt=0;//
// EVP_BytesToKey(EVP_rc2_ecb(),EVP_md5(),NULL,passwd,strlen(passwd),1,key,iv);
unsigned char key[] = "01234567ab";
unsigned char iv[] = "12345678";
// 修改参数
EVP_CIPHER_CTX_init(&ctx);
// EVP_CipherInit_ex(&ctx, EVP_rc2(), NULL, NULL, NULL, do_encrypt);
EVP_CipherInit_ex(&ctx, EVP_rc2_cfb(), NULL, NULL, NULL, do_encrypt);
EVP_CIPHER_CTX_set_key_length(&ctx, 10);
//完成参数设置,进行key和IV的设置
EVP_CipherInit_ex(&ctx, NULL, NULL, key, iv, do_encrypt);
for(;;)
{
inlen = fread(inbuf, 1, 1024, in);
if(inlen <= 0) break;
if(!EVP_CipherUpdate(&ctx, outbuf, &outlen, inbuf, inlen))
{
/*出错处理 */
return 0;
}
fwrite(outbuf, 1, outlen, out);
printf("%d\n",outlen);
} 展开
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询