Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Tcl) SFTP Read Directory ListingSee more SFTP ExamplesDemonstrates how to download a directory listing and iterate over the files.
load ./chilkat.dll # This requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. # Important: It is helpful to send the contents of the # sftp.LastErrorText property when requesting support. set sftp [new_CkSFtp] # Set some timeouts, in milliseconds: CkSFtp_put_ConnectTimeoutMs $sftp 5000 CkSFtp_put_IdleTimeoutMs $sftp 10000 # Connect to the SSH server. # The standard SSH port = 22 # The hostname may be a hostname or IP address. set hostname "www.my-sftp-server.com" set port 22 set success [CkSFtp_Connect $sftp $hostname $port] if {$success != 1} then { puts [CkSFtp_lastErrorText $sftp] delete_CkSFtp $sftp exit } # Authenticate with the SSH server. Chilkat SFTP supports # both password-based authenication as well as public-key # authentication. This example uses password authenication. set success [CkSFtp_AuthenticatePw $sftp "myLogin" "myPassword"] if {$success != 1} then { puts [CkSFtp_lastErrorText $sftp] delete_CkSFtp $sftp exit } # After authenticating, the SFTP subsystem must be initialized: set success [CkSFtp_InitializeSftp $sftp] if {$success != 1} then { puts [CkSFtp_lastErrorText $sftp] delete_CkSFtp $sftp exit } # Open a directory on the server... # Paths starting with a slash are "absolute", and are relative # to the root of the file system. Names starting with any other # character are relative to the user's default directory (home directory). # A path component of ".." refers to the parent directory, # and "." refers to the current directory. set handle [CkSFtp_openDir $sftp "."] if {[CkSFtp_get_LastMethodSuccess $sftp] != 1} then { puts [CkSFtp_lastErrorText $sftp] delete_CkSFtp $sftp exit } # Download the directory listing: # dirListing is a CkSFtpDir set dirListing [CkSFtp_ReadDir $sftp $handle] if {[CkSFtp_get_LastMethodSuccess $sftp] != 1} then { puts [CkSFtp_lastErrorText $sftp] delete_CkSFtp $sftp exit } # Close the handle for the directory listing. set success [CkSFtp_CloseHandle $sftp $handle] if {$success != 1} then { puts [CkSFtp_lastErrorText $sftp] delete_CkSFtp $sftp exit } # Iterate over the files. set i 0 set n [CkSFtpDir_get_NumFilesAndDirs $dirListing] while {$i < $n} { # fileObj is a CkSFtpFile set fileObj [CkSFtpDir_GetFileObject $dirListing $i] puts [CkSFtpFile_filename $fileObj] puts [CkSFtpFile_fileType $fileObj] puts "Size in bytes: [CkSFtpFile_get_Size32 $fileObj]" puts "----" delete_CkSFtpFile $fileObj set i [expr $i + 1] } delete_CkSFtpDir $dirListing puts "Success." delete_CkSFtp $sftp |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.