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
(Delphi ActiveX) Blowfish OFB Output Feedback Mode EncryptionDemonstrates how to encrypt using Blowfish OFB (Output Feedback) mode.
uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Chilkat_TLB; ... procedure TForm1.Button1Click(Sender: TObject); var crypt: TChilkatCrypt2; ivHex: WideString; keyHex: WideString; encStr: WideString; decrypt: TChilkatCrypt2; decStr: WideString; begin // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. crypt := TChilkatCrypt2.Create(Self); // Use "blowfish2" to produce correct results that match published blowfish test vectors. crypt.CryptAlgorithm := 'blowfish2'; // Set the cipher mode to Output Feedback crypt.CipherMode := 'ofb'; crypt.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.EncodingMode := 'hex'; // The block size of the blowfish algoirthm is 8 bytes, therefore the IV is 8 bytes. ivHex := '0001020304050607'; crypt.SetEncodedIV(ivHex,'hex'); // The secret key must equal the size of the key. For // 256-bit encryption, the binary secret key is 32 bytes. keyHex := '603deb1015ca71be2b73aef0857d77811f352c073b6108d72d9810a30914dff4'; crypt.SetEncodedKey(keyHex,'hex'); // Encrypt a string... encStr := crypt.EncryptStringENC('Emergencies have always been the pretext on which the safeguards of individual liberty have been eroded. -- Friedrich Hayek'); Memo1.Lines.Add(encStr); decrypt := TChilkatCrypt2.Create(Self); decrypt.CryptAlgorithm := 'blowfish2'; decrypt.CipherMode := 'ofb'; decrypt.KeyLength := 256; decrypt.EncodingMode := 'hex'; decrypt.SetEncodedIV(ivHex,'hex'); decrypt.SetEncodedKey(keyHex,'hex'); // Now decrypt: decStr := decrypt.DecryptStringENC(encStr); Memo1.Lines.Add(decStr); end; |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.