Chilkat
HOME
Android™
ASP
Visual Basic
VB.NET
C#
iOS (IPhone)
Objective-C
C++
C
MFC
Delphi
FoxPro
Java
Perl
PHP Extension
PHP ActiveX
Python
PowerShell
Ruby
SQL Server
VBScript
|
SFTP Resume UploadDemonstrates how to resume an SFTP upload to an SSH server. The ResumeUploadFileByName method checks the size of the file on the remote server and begins uploading from the appropriate position in the local file.
CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int DECLARE @sTmp0 nvarchar(4000) -- Important: It is helpful to send the contents of the -- sftp.LastErrorText property when requesting support. DECLARE @sftp int EXEC @hr = sp_OACreate 'Chilkat.SFtp', @sftp OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END -- Any string automatically begins a fully-functional 30-day trial. DECLARE @success int EXEC sp_OAMethod @sftp, 'UnlockComponent', @success OUT, 'Anything for 30-day trial' IF @success <> 1 BEGIN EXEC sp_OAGetProperty @sftp, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 RETURN END -- Set some timeouts, in milliseconds: EXEC sp_OASetProperty @sftp, 'ConnectTimeoutMs', 5000 EXEC sp_OASetProperty @sftp, 'IdleTimeoutMs', 10000 -- Connect to the SSH server. -- The standard SSH port = 22 -- The hostname may be a hostname or IP address. DECLARE @port int DECLARE @hostname nvarchar(4000) SELECT @hostname = 'www.my-ssh-server.com' SELECT @port = 22 EXEC sp_OAMethod @sftp, 'Connect', @success OUT, @hostname, @port IF @success <> 1 BEGIN EXEC sp_OAGetProperty @sftp, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 RETURN END -- Authenticate with the SSH server. Chilkat SFTP supports -- both password-based authenication as well as public-key -- authentication. This example uses password authenication. EXEC sp_OAMethod @sftp, 'AuthenticatePw', @success OUT, 'myLogin', 'myPassword' IF @success <> 1 BEGIN EXEC sp_OAGetProperty @sftp, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 RETURN END -- After authenticating, the SFTP subsystem must be initialized: EXEC sp_OAMethod @sftp, 'InitializeSftp', @success OUT IF @success <> 1 BEGIN EXEC sp_OAGetProperty @sftp, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 RETURN END -- Upload from the local file to the SSH server. -- Important -- the remote filepath is the 1st argument, -- the local filepath is the 2nd argument; DECLARE @remoteFilePath nvarchar(4000) SELECT @remoteFilePath = 'hamlet.xml' DECLARE @localFilePath nvarchar(4000) SELECT @localFilePath = 'c:/temp/hamlet.xml' -- The ResumeUploadFileByName method first gets the size -- of the partial file on the server and then begins uploading -- from the appropriate point in the local file. -- If the remote file does not exist or is 0-length, this -- method is equivalent to UploadFileByName. -- If the remote file is already equal to or larger in size -- than the local file, then nothing more is uploaded. EXEC sp_OAMethod @sftp, 'ResumeUploadFileByName', @success OUT, @remoteFilePath, @localFilePath IF @success <> 1 BEGIN EXEC sp_OAGetProperty @sftp, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 RETURN END PRINT 'Success.' END GO |
© 2000-2010 Chilkat Software, Inc. All Rights Reserved.