У меня есть этот код
.....
const EVP_CIPHER * cipher = EVP_des_ecb();
uint8_t ot_byte,st_byte;
EVP_CIPHER_CTX ctx;
int trash;
EVP_EncryptInit(&ctx,cipher, key, iv);
cout << size - offset << endl;
int i=0;
for (; i < size - offset ;i++){
check = read(input_fd,&ot_byte,1);
cout << (i < size - offset) << " " << i << endl;
EVP_EncryptUpdate(&ctx, &st_byte, &trash, &ot_byte, 1);
check = write(output_fd,&st_byte,1);
}
cout << (i < size - offset) << " " << i << endl;
close(output_fd);
close(output_fd);
выход
702000
1 0
1 1
1 2
1 3
1 4
1 5
1 6
1 7
0 5019693
Когда я «комментирую» функцию обновления EVP, цикл проходит все 702000 итераций. Где ошибка? Есть ли вероятность, что EVP как-то идет за буфер и портит данные стека?
Тип uint8_t будет маленьким, эти функции возвращают не менее 8 байтов
Других решений пока нет …