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

 

 

 

 

 

 

 

Asynchronous FTP Download

The Chilkat FTP component supports asynchronous uploads and downloads. This examples demonstrates doing a download in a background thread. The download is started by calling AsyncGetFileStart. While the download is in progress, your program may do other tasks. You may periodically check the AsyncFinished property to determine when the transfer is finished. The example below provides the remainder of the details.

Download Chilkat Perl Module

use chilkat;

$ftp = new chilkat::CkFtp2();

#  Any string unlocks the component for the 1st 30-days.
$success = $ftp->UnlockComponent("Anything for 30-day trial");
if ($success != 1) {
    print $ftp->lastErrorText() . "\n";
    exit;
}

$ftp->put_Hostname("www.secureftp-test.com");
$ftp->put_Username("test");
$ftp->put_Password("test");

#  Connect and login to the FTP server.
$success = $ftp->Connect();
if ($success != 1) {
    print $ftp->lastErrorText() . "\n";
    exit;
}

$localFilename = "hamlet.xml";
$remoteFilename = "hamlet.xml";

#  Begin the download in a background thread.
#  Only 1 background upload or download may be active at any time.
#  (per instance of an FTP object)
$success = $ftp->AsyncGetFileStart($remoteFilename,$localFilename);
if ($success != 1) {
    print $ftp->lastErrorText() . "\n";
    exit;
}

#  The application is now free to do anything else
#  while the file is downloading.
#  For this example, we'll simply sleep and periodically
#  check to see if the transfer if finished.  While checking
#  however, we'll report on the progress in both number
#  of bytes tranferred and performance in bytes/second.
while ($ftp->get_AsyncFinished() != 1) {

    print $ftp->get_AsyncBytesReceived() . " bytes received" . "\r\n";
    print $ftp->get_DownloadRate() . " bytes per second" . "\r\n";

    #  Sleep 1 second.
    $ftp->SleepMs(1000);
}

#  Did the download succeed?
if ($ftp->get_AsyncSuccess() == 1) {
    print "File Downloaded!" . "\n";
}
else {
    #  The error information for asynchronous ops
    #  is in AsyncLog as opposed to LastErrorText
    print $ftp->asyncLog() . "\n";
}

$ftp->Disconnect();
 

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

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