首先是 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 指向)
不必担心数据长度,实际上它所采用的输入来自一个/w ip
数据包,因此它可以提供高达 1024 字节的数据,并且文件内容永远不会超过此限制。
这是我的尝试(也出于调试目的,我需要提及 file.enc 的内容以及标准输出的数据部分)
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)
。
请帮助我...如果需要有关此的任何进一步信息,我将添加它。