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

Unreleased...
Service
PPMD
Deflate
Bzip2
LZW
Bz2
DH Key Exchange
DSA
Icon

 

 

 

 

 

 

 

Deflate String

Compresses a string using the Deflate compression algorithm.

The functionality in this example is available in pre-release only:

Chilkat Module for Perl 5.8.* (Pre-Release)

Chilkat Module for Perl 5.10.* (Pre-Release)

use chilkat;

$compress = new chilkat::CkCompression();

#  Any string argument automatically begins a 30-day trial.
$success = $compress->UnlockComponent("30-day trial");
if ($success != 1) {
    print "Compression component unlock failed" . "\n";
    exit;
}

$compress->put_Algorithm("deflate");

#  Create a long string to deflate.
$strData = "abcdefg1122334455667788";
$strData = $strData . "\r\n";
for ($i = 0; $i <= 99; $i++) {
    $strData = $strData . "abcdefg1122334455667788";
    $strData = $strData . "\r\n";
}

#  Depending on the programming language, the string
#  may be Unicode.  Tell the component to convert to
#  ansi (1-byte/char) prior to compression:
$compress->put_Charset("ansi");

#  Compressed data is binary, meaning that all byte values
#  from 0 to 255 are possible.  The result would not be
#  a printable string.  To receive a printable string (us-ascii),
#  the resultant compressed data should be encoded using
#  an encoding such as base64.  Set the EncodingMode
#  property to determine the output encoding:
#  (Valid choices are "base64", "hex", "url", and others)
$compress->put_EncodingMode("base64");

#  Note: Base64 encoding expands the compressed data by
#  4/3rds because each 3 bytes of binary data are represented
#  by 4 printable chars.  Hex, for example, doubles the output
#  size because each byte is represented by 2 printable chars.

#  Deflate the string:

$deflatedStr = $compress->compressStringENC($strData);
if ($deflatedStr eq null ) {
    print $compress->lastErrorText() . "\n";
    exit;
}

#  Display the deflated string.
#  The result will be:
#  S0xKTklNSzc0NDIyNjYxMTU1MzM3t7Dg5UoclRiVGJUYlRiVGJUYlRiVGJUYchIA
print $deflatedStr . "\r\n";

#  Decompress back to the original:

$strOriginal = $compress->decompressStringENC($deflatedStr);

#  Display the uncompressed original:
print "--- Original ---" . "\r\n";
print $strOriginal . "\r\n";
 

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

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