Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Unicode C++) Blowfish CFB Mode EncryptionDemonstrates how to encrypt using Blowfish CFB (Cipher Feedback) mode.
#include <CkCrypt2W.h> void ChilkatSample(void) { // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkCrypt2W crypt; // Use "blowfish2" to produce correct results that match published blowfish test vectors. crypt.put_CryptAlgorithm(L"blowfish2"); crypt.put_CipherMode(L"cfb"); crypt.put_KeyLength(256); // EncodingMode specifies the encoding of the output for // encryption, and the input for decryption. // It may be "hex", "url", "base64", "quoted-printable", or many other choices. crypt.put_EncodingMode(L"hex"); // The block size of the blowfish algoirthm is 8 bytes, therefore the IV is 8 bytes. const wchar_t *ivHex = L"0001020304050607"; crypt.SetEncodedIV(ivHex,L"hex"); // The secret key must equal the size of the key. For // 256-bit encryption, the binary secret key is 32 bytes. const wchar_t *keyHex = L"603deb1015ca71be2b73aef0857d77811f352c073b6108d72d9810a30914dff4"; crypt.SetEncodedKey(keyHex,L"hex"); // Encrypt a string... const wchar_t *encStr = crypt.encryptStringENC(L"In all intellectual debates, both sides tend to be correct in what they affirm, and wrong in what they deny. -- John Stuart Mill"); wprintf(L"%s\n",encStr); CkCrypt2W decrypt; decrypt.put_CryptAlgorithm(L"blowfish2"); decrypt.put_CipherMode(L"cfb"); decrypt.put_KeyLength(256); decrypt.put_EncodingMode(L"hex"); decrypt.SetEncodedIV(ivHex,L"hex"); decrypt.SetEncodedKey(keyHex,L"hex"); // Now decrypt: const wchar_t *decStr = decrypt.decryptStringENC(encStr); wprintf(L"%s\n",decStr); } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.