SQL Server
SQL Server
Bunny Edge Storage - Upload File
See more Bunny CDN Examples
Upload a file to a storage zone based on the URL path. If the directory tree does not exist, it will be created automatically. The file content should be sent as the body of the request without any type of encoding.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
-- 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 assumes the Chilkat API to have been previously unlocked.
-- See Global Unlock Sample for sample code.
DECLARE @http int
EXEC @hr = sp_OACreate 'Chilkat.Http', @http OUT
IF @hr <> 0
BEGIN
PRINT 'Failed to create ActiveX component'
RETURN
END
-- Use the "Password" from the "FTP & HTTP API Access" console web page for your Bunny storage zone.
EXEC sp_OAMethod @http, 'SetRequestHeader', NULL, 'AccessKey', 'YOUR_FTP_AND_HTTP_PASSWORD'
-- Here I am using a relative file path (relative to the current working directory of the process).
-- You may wish to change it to an absolute file path, such as "C:/someDir/..." if on Windows.
DECLARE @localFilePath nvarchar(4000)
SELECT @localFilePath = 'qa_data/jpg/penguins.jpg'
-- Important:
-- Storage Endpoints:
-- The storage API endpoint depends on the primary storage region of your storage zone. You can also find this in the FTP & HTTP API Information of your storage zone.
-- Falkenstein: storage.bunnycdn.com
-- New York: ny.storage.bunnycdn.com
-- Los Angeles: la.storage.bunnycdn.com
-- Singapore: sg.storage.bunnycdn.com
-- Sydney: syd.storage.bunnycdn.com
-- London: uk.storage.bunnycdn.com
-- ... (possibly others??)
-- If you use the incorrect storage endpoint, you will get a "401 Unauthorized" response.
-- Make sure to change the "storageZoneName" to your actual storage zone name.
-- You can choose to upload to a sub-directory, such as "testDir", or not.
DECLARE @resp int
EXEC @hr = sp_OACreate 'Chilkat.HttpResponse', @resp OUT
EXEC sp_OAMethod @http, 'HttpFile', @success OUT, 'PUT', 'https://uk.storage.bunnycdn.com/storageZoneName/testDir/penguins.jpg', @localFilePath, 'application/octet-stream', @resp
IF @success = 0
BEGIN
EXEC sp_OAGetProperty @http, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @http
EXEC @hr = sp_OADestroy @resp
RETURN
END
DECLARE @respStatusCode int
EXEC sp_OAGetProperty @resp, 'StatusCode', @respStatusCode OUT
PRINT 'Response Status Code = ' + @respStatusCode
IF @respStatusCode >= 400
BEGIN
PRINT 'Response Header:'
EXEC sp_OAGetProperty @resp, 'Header', @sTmp0 OUT
PRINT @sTmp0
EXEC sp_OAGetProperty @resp, 'BodyStr', @sTmp0 OUT
PRINT @sTmp0
PRINT 'Failed.'
END
ELSE
BEGIN
PRINT 'Success.'
END
-- A 201 status code is returned for a successful upload.
-- The response body for a successful upload is empty.
EXEC @hr = sp_OADestroy @http
EXEC @hr = sp_OADestroy @resp
END
GO