Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(C++) Streaming EncryptionEncrypt and decrypt using a stream.
#include <CkCrypt2.h> #include <CkStream.h> #include <CkStringArray.h> #include <CkTask.h> void ChilkatSample(void) { // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkCrypt2 crypt; // Setup encryption using the chacha20 algorithm... crypt.put_CryptAlgorithm("chacha20"); crypt.put_KeyLength(256); crypt.put_EncodingMode("hex"); const char *ivHex = "000000000000000000000002"; crypt.SetEncodedIV(ivHex,"hex"); crypt.put_InitialCount(42); const char *keyHex = "1c9240a5eb55d38af333888604f6b5f0473917c1402b80099dca5cbc207075c0"; crypt.SetEncodedKey(keyHex,"hex"); const char *plainText = "The quick brown fox jumped over the lazy dog.\r\n"; CkStream stream; // We'll save the encrypted output in eStrings to demonstrate streaming decryption next. CkStringArray eStrings; // Start a background task that will encrypt a stream. CkTask *task = crypt.EncryptStreamAsync(stream); bool success = task->Run(); // Write plainText to the stream, and read chacha20 encrypted text.. const char *cipherText = 0; int i; for (i = 1; i <= 10; i++) { // Note: An encryption algorithm's block size will cause buffering, // and therefore not every loop iteration will produce output. success = stream.WriteString(plainText); if (stream.get_DataAvailable() == true) { cipherText = stream.readBytesENC("hex"); std::cout << cipherText << "\r\n"; success = eStrings.Append(cipherText); } } // Tell the background task that the stream has ended. success = stream.WriteClose(); // Let's make sure the background task finished. // It should already be the case that the task is finished. while ((task->get_Finished() != true)) { task->SleepMs(20); } // Get any remaining data available from the stream. if (stream.get_DataAvailable() == true) { cipherText = stream.readBytesENC("hex"); std::cout << cipherText << "\r\n"; success = eStrings.Append(cipherText); } if (task->get_TaskSuccess() != true) { std::cout << "async encryption failed:" << "\r\n"; std::cout << task->resultErrorText() << "\r\n"; success = false; } delete task; std::cout << "-- encrypt finished --" << "\r\n"; // Now decrypt to return the original. // Reset the stream object so it can be used again. stream.Reset(); // Start a background task that will decrypt a stream. task = crypt.DecryptStreamAsync(stream); success = task->Run(); int n = eStrings.get_Count(); for (i = 0; i <= n - 1; i++) { success = stream.WriteBytesENC(eStrings.getString(i),"hex"); if (stream.get_DataAvailable() == true) { plainText = stream.readString(); std::cout << plainText << "\r\n"; } } // Tell the background task that the stream has ended. success = stream.WriteClose(); // Let's make sure the background task finished. // It should already be the case that the task is finished. while ((task->get_Finished() != true)) { task->SleepMs(20); } // Get any remaining data available from the stream. if (stream.get_DataAvailable() == true) { plainText = stream.readString(); std::cout << plainText << "\r\n"; } if (task->get_TaskSuccess() != true) { std::cout << "async decryption failed:" << "\r\n"; std::cout << task->resultErrorText() << "\r\n"; success = false; } delete task; std::cout << "-- decrypt finished --" << "\r\n"; } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.