gpt4 book ai didi

c - 将加密文件中的二进制数据写入指定的内存位置

转载 作者:行者123 更新时间:2023-11-30 16:00:34 24 4
gpt4 key购买 nike

首先是aes加密函数的代码:

void
xorcrypto(u_int8_t *key, u_int32_t keylen,
u_int8_t *data, u_int32_t datalen)
{

/*u_int8_t ....etc are alias for uint8_t...etc so don't bother about them*/

FILE *fp,*fq,*fr;
int i;
fp=fopen("key","wb");
fwrite((char *)key,keylen,1,fp);
fq=fopen("file.txt","wb");
fwrite((char *)data,datalen,1,fq);

fclose(fq);
fclose(fp);

system("sudo openssl enc -aes-256-cbc -salt -in file.txt
-out file.enc -pass file:key");


/* Here is the code section i need*/

}

我在上面指定的代码部分中需要的是它应该能够
使用文件 file.enc 的内容填充/更改数据(由 u_int8_t*data 指向)

不用担心数据长度,实际上它所获取的输入是来自 n/w ip
数据包,因此它可以提供高达 1024 字节的数据,并且文件内容永远不会超过此限制。

这是我的尝试(也是出于调试目的,我需要提及 file.enc 的内容以及 stdout 的数据部分)

fr=fopen("file.enc","rb");
memset(data,0,sizeof(data));

i=0;

while( (ch=fgetc(fr))==EOF) {
data[i]=ch;
i++;
}

data[i]='\0';
i=0;
puts((char *)data);
printf("\n");
fclose(fr);

这里有一些输出快照可能会有所帮助......

udit@udit-Dabba ~/Downloads/sendip-2.5-mec-2/mec $ cat key
thisisaeskey

udit@udit-Dabba ~/Downloads/sendip-2.5-mec-2/mec $ cat file.txt
w�uP����abcd

udit@udit-Dabba ~/Downloads/sendip-2.5-mec-2/mec $ cat file.enc
Salted__����a�dR�P��l�C-<��y�O^Z��/a��3����Q

udit@udit-Dabba ~/Downloads/sendip-2.5-mec-2/mec $ hexdump -C file.enc
00000000 53 61 6c 74 65 64 5f 5f b6 f2 b2 d0 61 d9 64 1c |Salted__....a.d.|
00000010 52 e0 50 96 e8 6c 0e c0 43 2d 3c c4 f6 79 1b d2 |R.P..l..C-<..y..|
00000020 4f 5e 5a b1 d6 2f 61 f8 15 f6 33 e1 88 f0 db 51 |O^Z../a...3....Q|
00000030
udit@udit-Dabba ~/Downloads/sendip-2.5-mec-2/mec $

该函数无法更改指向位置 (u_int8_t *data) 的内容,因此无法在 stdout puts(data) 上写入数据。

请帮助我解决这个问题...如果需要任何进一步的信息,我将添加它。

最佳答案

尝试改变

while( (ch=fgetc(fr))==EOF)

进入

while( (ch=fgetc(fr))!=EOF)

关于c - 将加密文件中的二进制数据写入指定的内存位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7626646/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com