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 Upload

The Chilkat FTP component supports asynchronous uploads and downloads. This examples demonstrates doing an upload in a background thread. The upload is started by calling AsyncPutFileStart. While the upload 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.akronbackups.com");
$ftp->put_Username("*myLogin6*");
$ftp->put_Password("*myPassword6*");

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

# Change to the remote directory where the file will be uploaded.
$success = $ftp->ChangeRemoteDir("junk");
if ($success != 1) {
    print $ftp->lastErrorText() . "\n";
    exit;
}

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

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

# The application is now free to do anything else
# while the file is uploading.
# 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_AsyncBytesSent() . " bytes sent" . "\r\n";
    print $ftp->get_UploadRate() . " bytes per second" . "\r\n";

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

# Did the upload succeed?
if ($ftp->get_AsyncSuccess() == 1) {
    print "File Uploaded!" . "\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.