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) Crypt2 Compression ExampleThe Chilkat Crypt2 class include a few methods for compression and decompression (inflate). These are legacy method that existed long before the Chilkat.Compression class was first introduced. These methods should be avoided in favor of using the Chilkat.Compression methods. The reason is that they are limited to bzip2, and the compressed output includes an 8-byte header that is composed of a magic number (0xB394A7E1) and the size of the original uncompressed data (4 bytes and thus limited to 4GB). This example demonstrates compression and decompression, and also how to compress using Crypt2 and decompress using Chilkat.Compression. The Chilkat.Compression class does not emit any header, and supports other compression methods.
#include <C_CkCrypt2.h> #include <C_CkStringBuilder.h> #include <C_CkCompression.h> #include <C_CkBinData.h> void ChilkatSample(void) { HCkCrypt2 crypt; HCkStringBuilder sb; int i; const char *compressedStr; const char *originalStr; HCkCompression compress; HCkBinData bd; // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. crypt = CkCrypt2_Create(); sb = CkStringBuilder_Create(); i = 0; while (i < 10) { CkStringBuilder_AppendInt(sb,i); CkStringBuilder_Append(sb," the quick brown fox jumps over the crazy dog\r\n"); i = i + 1; } printf("Before compression:\n"); printf("%s\n",CkStringBuilder_getAsString(sb)); // Before compression: // 0 the quick brown fox jumps over the crazy dog // 1 the quick brown fox jumps over the crazy dog // 2 the quick brown fox jumps over the crazy dog // 3 the quick brown fox jumps over the crazy dog // 4 the quick brown fox jumps over the crazy dog // 5 the quick brown fox jumps over the crazy dog // 6 the quick brown fox jumps over the crazy dog // 7 the quick brown fox jumps over the crazy dog // 8 the quick brown fox jumps over the crazy dog // 9 the quick brown fox jumps over the crazy dog CkCrypt2_putEncodingMode(crypt,"base64"); // Compress the utf-8 representation of the string. // Note: Choosing "Unicode" or "utf-16" is a poor choice for text that is mostly us-ascii. // The utf-8 representation will result in a smaller size. CkCrypt2_putCharset(crypt,"utf-8"); compressedStr = CkCrypt2_compressStringENC(crypt,CkStringBuilder_getAsString(sb)); printf("After compression:\n"); printf("%s\n",compressedStr); // After compression: // 4aeUs+ABAABCWmgzMUFZJlNZT/+H9wAAN1mAABJAAH/gP/v/8CAAkDGExNBgjEMjCYFKqGoAaDygNDamyTYmKe6Ypqn0mqZpgmaZd/hv8fLz9McsU7kyTgmwnAmibU4pyJom5PxNqapxTBO1M05JuT4TrT+TRMCapqm9VzTmn+LuSKcKEgn/8P7g // Note: The compressed data includes an 8-byte header composed of a magic number (0xB394A7E1) and the original data byte count. // Therefore, the Crypt2 compress/inflate methods are considered legacy and should only be used for data already // compressed with these methods. The Chilkat.Compression class is generalized, emits no headers, and can interoperate with // with other software systems without trouble. // If we re-encode from base64 to hex, then we can see the header: printf("%s\n",CkCrypt2_reEncode(crypt,compressedStr,"base64","hex")); // The hex compressed string is: // E1A794B3E0010000425A68333141592653594... // We can see the 8-byte header in the hex: magic number = 0xE1A794B3E (little-endian), and byte count = 0xE0010000 (little-endian) originalStr = CkCrypt2_inflateStringENC(crypt,compressedStr); printf("After inflate:\n"); printf("%s\n",originalStr); // --------------------------------------------------------------------------- // To inflate with Chilkat.Compression: compress = CkCompression_Create(); CkCompression_putAlgorithm(compress,"bzip2"); CkCompression_putCharset(compress,"utf-8"); CkCompression_putEncodingMode(compress,"base64"); bd = CkBinData_Create(); CkBinData_AppendEncoded(bd,compressedStr,"base64"); // Remove the 1st 8 bytes. CkBinData_RemoveChunk(bd,0,8); CkCompression_DecompressBd(compress,bd); printf("After decompression:\n"); printf("%s\n",CkBinData_getString(bd,"utf-8")); CkCrypt2_Dispose(crypt); CkStringBuilder_Dispose(sb); CkCompression_Dispose(compress); CkBinData_Dispose(bd); } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.