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
(Delphi DLL) Twofish OFB Output Feedback Mode EncryptionDemonstrates how to encrypt using Twofish 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, Crypt2; ... procedure TForm1.Button1Click(Sender: TObject); var crypt: HCkCrypt2; ivHex: PWideChar; keyHex: PWideChar; encStr: PWideChar; decrypt: HCkCrypt2; decStr: PWideChar; begin // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. crypt := CkCrypt2_Create(); CkCrypt2_putCryptAlgorithm(crypt,'twofish'); // Set the cipher mode to Output Feedback CkCrypt2_putCipherMode(crypt,'ofb'); CkCrypt2_putKeyLength(crypt,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. CkCrypt2_putEncodingMode(crypt,'hex'); ivHex := '000102030405060708090A0B0C0D0E0F'; CkCrypt2_SetEncodedIV(crypt,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'; CkCrypt2_SetEncodedKey(crypt,keyHex,'hex'); // Encrypt a string... encStr := CkCrypt2__encryptStringENC(crypt,'Without music to decorate it, time is just a bunch of boring production deadlines or dates by which bills must be paid. -- Frank Zappa'); Memo1.Lines.Add(encStr); decrypt := CkCrypt2_Create(); CkCrypt2_putCryptAlgorithm(decrypt,'twofish'); CkCrypt2_putCipherMode(decrypt,'ofb'); CkCrypt2_putKeyLength(decrypt,256); CkCrypt2_putEncodingMode(decrypt,'hex'); CkCrypt2_SetEncodedIV(decrypt,ivHex,'hex'); CkCrypt2_SetEncodedKey(decrypt,keyHex,'hex'); // Now decrypt: decStr := CkCrypt2__decryptStringENC(decrypt,encStr); Memo1.Lines.Add(decStr); CkCrypt2_Dispose(crypt); CkCrypt2_Dispose(decrypt); end; |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.