¿Cuál es la diferencia entre el objeto en modo plantilla y el objeto de cifrado externo?
Como en el título, estoy buscando eldiferencia en la biblioteca cryptopp entreesta declaración:
CBC_Mode<AES>::Decryption
cbcDecryption.SetKeyWithIV(key, AES::DEFAULT_KEYLENGTH, iv);
yéste:
AES::Decryption aesDecryption(key, AES::DEFAULT_KEYLENGTH);
CBC_Mode_ExternalCipher::Decryption cbcDecryption( aesDecryption, iv );
Además, no puedo entender por qué con esto:
AES::Decryption aesDecryption(key, AES::DEFAULT_KEYLENGTH);
CBC_Mode_ExternalCipher::Decryption cbcDecryption( aesDecryption, iv );
StreamTransformationFilter stfDecryptor(
cbcDecryption,
new StringSink( recoveredtext )
);
stfDecryptor.Put( reinterpret_cast<const unsigned char*>( ciphertext.c_str() ), ciphertext.size() );
stfDecryptor.MessageEnd();
todo funciona bien mientras uso el modo de plantilla tengo este error durantetiempo de ejecución:
AES128CBC: /usr/local/include/cryptopp/misc.h:304: void CryptoPP::memcpy_s(void*, size_t, const void*, size_t): Assertion `dest != __null' failed.
Aborted (core dumped)
¿No debería ser lo mismo?
He miradoesta pero no entendí bien la diferencia y buscando en la red no pude encontrar una respuesta a mi problema.