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
|
(SQL Server) SFTP Simplified DownloadDemonstrates how to SFTP download a file by passing a remote filepath to DownloadFileByName.
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', 15000 EXEC sp_OASetProperty @sftp, 'IdleTimeoutMs', 15000 -- 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 -- Download the file: DECLARE @remoteFilePath nvarchar(4000) DECLARE @localFilePath nvarchar(4000) SELECT @localFilePath = 'c:/temp/hamlet.xml' -- Note: The remote filepath may be an absolute filepath, -- a relative filepath, or simply a filename. -- Relative filepaths are always relative to the home directory -- of the SFTP/SSH user account. There is no such thing -- as "current remote directory" in the SFTP protocol. -- A filename with no path implies that the file is located -- in the SFTP user account's home directory. SELECT @remoteFilePath = 'subdir1/subdir2/hamlet.xml' EXEC sp_OAMethod @sftp, 'DownloadFileByName', @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.