Perl Examples

ChilkatHOMEASPVisual BasicVB.NETC#Visual C++CMFCDelphiFoxProJavaPerlPHPPythonRubySQL ServerVBScript



Perl Examples

Quick Start
Perl Unicode
Perl Byte Array
Perl Certs
Perl Email
Perl Encryption
Perl FTP
HTML-to-XML
Perl HTTP
Perl IMAP
Perl MHT
Perl MIME
Perl RSA
Perl S/MIME
Perl Signatures
Perl Socket
Perl Spider
Perl Tar
Perl Upload
Perl XML
Perl XMP
Perl Zip

More Examples...
String
Email Object
POP3
SMTP
RSS
Atom
Self-Extractor
Service
PPMD
Deflate
DH Key Exchange
DSA

Unreleased...
Bzip2
LZW
Bz2
Icon

 

 

 

 

 

 

 

Perl Blowfish CBC Encryption Matching Published Test Vectors

Perl script for Blowfish CBC encryption.

Download Perl Programming Example Scripts

# file: blowfishCBC.pl

use chilkat;

# Perl Blowfish CBC Encryption to match published test vector
# at http://www.schneier.com/code/vectors.txt
# Reproduced here:
# chaining mode test data
# key[16]  (0123456789ABCDEFF0E1D2C3B4A59687
# IV [8](FEDCBA9876543210
# data[29] ("7654321 Now is the time for " (includes trailing '\0')
# vdata[29] (37363534333231204E6F77206973207468652074696D6520666F722000
# cipher[32]= 6B77B4D63006DEE605B156E27403979358DEB9E7154616D959F1652BD5FF92CC
    
$crypt = new chilkat::CkCrypt2();
$crypt->UnlockComponent('anything for 30-day trial');
    
# Set the CryptAlgorithm to "blowfish2".  Chilkat's original implementation
# of Blowfish ("blowfish") did not include CBC and returned encrypted data
# 4321 byte-swapped.  For backward compatibility, an additional CryptAlgorithm
# keyword ("blowfish2") was added to indicate the new Blowfish implementation.
$crypt->put_CryptAlgorithm('blowfish2');
    
$crypt->put_CipherMode('cbc');
$crypt->put_KeyLength(128);
    
# Padding Schemes:
# 0((RFC2630) Each padding byte is the pad count (16 extra added if size is already a multiple of 16)
# 1(Random bytes except the last is the pad count (16 extra added if size is already multiple of 16)
# 2(Pad with random data. (If already a multiple of 16, no padding is added).
# 3(Pad with NULLs. (If already a multiple of 16, no padding is added).
# 4(Pad with SPACE chars(0x20). (If already a multiple of 16, no padding is added).
    
# To match the test vector output, we need to pad with NULL bytes.
$crypt->put_PaddingScheme(3);
    
# Set the IV property via an encoded string.
$crypt->SetEncodedIV('FEDCBA9876543210', 'hex');
    
# Set the SecretKey property via an encoded string.
$crypt->SetEncodedKey('0123456789ABCDEFF0E1D2C3B4A59687', 'hex');
    
# Get the unencrypted data.
$unencryptedData = new chilkat::CkByteData();
$crypt->Decode("37363534333231204E6F77206973207468652074696D6520666F722000", "hex",$unencryptedData);
    
# Now encrypted it using the settings required to match the Blowfish test vector results.
$crypt->put_EncodingMode("hex");
$encryptedHexString = new chilkat::CkString();
$crypt->EncryptBytesENC($unencryptedData,$encryptedHexString);
    
# Displays: 6B77B4D63006DEE605B156E27403979358DEB9E7154616D959F1652BD5FF92CC
printf("%s\n",$encryptedHexString->getString());




 

Need a specific example? Send a request to support@chilkatsoft.com

© 2000-2007 Chilkat Software, Inc. All Rights Reserved.