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 Encryption to Match PHP's Mcrypt ExtensionDemonstrates how to match Blowfish encryption results with PHP's mcrypt extension. Please refer to this PHP (non-Chilkat) example for PHP Blowfish Encryption. The code here matches the PHP mcrypt results on that web page.
#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 get proper results: crypt.put_CryptAlgorithm(L"blowfish2"); // CipherMode may be "ecb" or "cbc" crypt.put_CipherMode(L"cbc"); // KeyLength (in bits) may be a number between 32 and 448. // 128-bits is usually sufficient. The KeyLength must be a // multiple of 8. crypt.put_KeyLength(256); // Pad with NULL bytes (PHP pads with NULL bytes) crypt.put_PaddingScheme(3); // EncodingMode specifies the encoding of the output for // encryption, and the input for decryption. // It may be "hex", "url", "base64", or "quoted-printable". crypt.put_EncodingMode(L"hex"); // The blowfish algorithm uses a 64-bit block size, // therefore the IV must be 8 bytes: const wchar_t *ivAscii = L"12345678"; crypt.SetEncodedIV(ivAscii,L"ascii"); // For 256-bit encryption, the key is 32 bytes: const wchar_t *keyAscii = L"1234567890123456ABCDEFGHIJKLMNOP"; crypt.SetEncodedKey(keyAscii,L"ascii"); const wchar_t *plainText = 0; plainText = L"The quick brown fox jumped over the lazy dog"; const wchar_t *cipherText = crypt.encryptStringENC(plainText); wprintf(L"%s\n",cipherText); // Output should be (case insensitive): // 276855ca6c0d60f7d9708210440c1072e05d078e733b34b4198d609dc2fcc2f0c30926cdef3b6d52baf6e345aa03f83e // Do 128-bit Blowfish encryption: crypt.put_KeyLength(128); keyAscii = L"1234567890123456"; crypt.SetEncodedKey(keyAscii,L"ascii"); cipherText = crypt.encryptStringENC(plainText); wprintf(L"%s\n",cipherText); // Output should be (case insensitive): // d2b5abb73208aea3790621d028afcc74d8dd65fb9ea8e666444a72523f5ecca60df79a424e2c714fa6efbafcc40bdca } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.