SQL Server
SQL Server
SCP Download/Upload Binary Files as Encoded Strings
See more SCP Examples
Demonstrates how to upload and download binary files as encoded strings (base64, hex, etc.) using the SCP protocol (Secure Copy Protocol over SSH).Chilkat SQL Server Downloads
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls.
--
CREATE PROCEDURE ChilkatSample
AS
BEGIN
DECLARE @hr int
DECLARE @iTmp0 int
-- Important: Do not use nvarchar(max). See the warning about using nvarchar(max).
DECLARE @sTmp0 nvarchar(4000)
DECLARE @success int
SELECT @success = 0
-- This example requires the Chilkat API to have been previously unlocked.
-- See Global Unlock Sample for sample code.
DECLARE @ssh int
EXEC @hr = sp_OACreate 'Chilkat.Ssh', @ssh OUT
IF @hr <> 0
BEGIN
PRINT 'Failed to create ActiveX component'
RETURN
END
-- Hostname may be an IP address or hostname:
DECLARE @hostname nvarchar(4000)
SELECT @hostname = 'www.some-ssh-server.com'
DECLARE @port int
SELECT @port = 22
-- Connect to an SSH server:
EXEC sp_OAMethod @ssh, 'Connect', @success OUT, @hostname, @port
IF @success <> 1
BEGIN
EXEC sp_OAGetProperty @ssh, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @ssh
RETURN
END
-- Wait a max of 5 seconds when reading responses..
EXEC sp_OASetProperty @ssh, 'IdleTimeoutMs', 5000
-- Authenticate using login/password:
EXEC sp_OAMethod @ssh, 'AuthenticatePw', @success OUT, 'myLogin', 'myPassword'
IF @success <> 1
BEGIN
EXEC sp_OAGetProperty @ssh, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @ssh
RETURN
END
-- Once the SSH object is connected and authenticated, we use it
-- in our SCP object.
DECLARE @scp int
EXEC @hr = sp_OACreate 'Chilkat.Scp', @scp OUT
EXEC sp_OAMethod @scp, 'UseSsh', @success OUT, @ssh
IF @success <> 1
BEGIN
EXEC sp_OAGetProperty @scp, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @ssh
EXEC @hr = sp_OADestroy @scp
RETURN
END
DECLARE @remotePath nvarchar(4000)
SELECT @remotePath = 'images/starfish.jpg'
-- Download the binary file and return as a base64 string.
-- See <a href="http://www.cknotes.com/chilkat-binary-encoding-list/">List of Encodings</a> for a list of possible encodings.
DECLARE @encodedJpg nvarchar(4000)
EXEC sp_OAMethod @scp, 'DownloadBinaryEncoded', @encodedJpg OUT, @remotePath, 'base64'
EXEC sp_OAGetProperty @scp, 'LastMethodSuccess', @iTmp0 OUT
IF @iTmp0 <> 1
BEGIN
EXEC sp_OAGetProperty @scp, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @ssh
EXEC @hr = sp_OADestroy @scp
RETURN
END
SELECT @remotePath = 'images/starfish2.jpg'
-- Now upload from the base64 string to the SSH server.
-- Insided the call to UploadBinaryEncoded, the base64 string is decoded,
-- and the decoded bytes are uploaded. The resulting starfish2.jpg on the
-- server will be identical to the original starfish.jpg
EXEC sp_OAMethod @scp, 'UploadBinaryEncoded', @success OUT, @remotePath, @encodedJpg, 'base64'
IF @success <> 1
BEGIN
EXEC sp_OAGetProperty @scp, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @ssh
EXEC @hr = sp_OADestroy @scp
RETURN
END
PRINT 'SCP download/upload binary encoded success.'
-- Disconnect
EXEC sp_OAMethod @ssh, 'Disconnect', NULL
EXEC @hr = sp_OADestroy @ssh
EXEC @hr = sp_OADestroy @scp
END
GO