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 Upload from Local FilesystemDemonstrates how to upload a file to an SSH server. There are no limitations on file size, and the file is streamed directly from the local filesystem.
load ./chilkat.dll # This example assumes the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. 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 "sftp.example.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 file for writing on the SSH server. # If the file already exists, it is overwritten. # (Specify "createNew" instead of "createTruncate" to # prevent overwriting existing files.) set handle [CkSFtp_openFile $sftp "hamlet.xml" "writeOnly" "createTruncate"] if {[CkSFtp_get_LastMethodSuccess $sftp] != 1} then { puts [CkSFtp_lastErrorText $sftp] delete_CkSFtp $sftp exit } # Upload from the local file to the SSH server. set success [CkSFtp_UploadFile $sftp $handle "c:/temp/hamlet.xml"] if {$success != 1} then { puts [CkSFtp_lastErrorText $sftp] delete_CkSFtp $sftp exit } # ----------------------------------------------------------------------------- # This is important. You must close the handle on the server. # Otherwise open handles will accumulate on the server until eventually a limit # is reached and the server will fail on a call to OpenFile. # ----------------------------------------------------------------------------- # Close the file. set success [CkSFtp_CloseHandle $sftp $handle] if {$success != 1} then { puts [CkSFtp_lastErrorText $sftp] delete_CkSFtp $sftp exit } puts "Success." delete_CkSFtp $sftp |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.