Sample code for 30+ languages & platforms
Visual FoxPro

Azure Storage: Upload Empty File to Block Blob

See more Azure Cloud Storage Examples

Demonstrates how to create an empty block blob in Azure Storage.

Chilkat Visual FoxPro Downloads

Visual FoxPro
LOCAL lnSuccess
LOCAL loRest
LOCAL lnBTls
LOCAL lnPort
LOCAL lnBAutoReconnect
LOCAL loAzAuth
LOCAL lcResponseStr

lnSuccess = 0

* Azure Blob Service Example: Demonstrates how to create an empty block blob.
* See also: https://msdn.microsoft.com/en-us/library/azure/dd179451.aspx

* This example requires the Chilkat API to have been previously unlocked.
* See Global Unlock Sample for sample code.

loRest = CreateObject('Chilkat.Rest')

* Connect to the Azure Storage Blob Service
lnBTls = 1
lnPort = 443
lnBAutoReconnect = 1
* In this example, the storage account name is "chilkat".
lnSuccess = loRest.Connect("chilkat.blob.core.windows.net",lnPort,lnBTls,lnBAutoReconnect)
IF (lnSuccess <> 1) THEN
    ? loRest.LastErrorText
    RELEASE loRest
    CANCEL
ENDIF

* Provide Azure Cloud credentials for the REST call.
loAzAuth = CreateObject('Chilkat.AuthAzureStorage')
loAzAuth.AccessKey = "AZURE_ACCESS_KEY"
* The account name used here should match the 1st part of the domain passed in the call to Connect (above).
loAzAuth.Account = "chilkat"
loAzAuth.Scheme = "SharedKey"
loAzAuth.Service = "Blob"
* This causes the "x-ms-version: 2021-08-06" header to be automatically added.
loAzAuth.XMsVersion = "2021-08-06"
lnSuccess = loRest.SetAuthAzureStorage(loAzAuth)

* Note: The application does not need to explicitly set the following
* headers: Content-Length, x-ms-date, Authorization.  These headers
* are automatically set by Chilkat.

* IMPORTANT: Make sure to set the x-ms-blob-type header:
lnSuccess = loRest.AddHeader("x-ms-blob-type","BlockBlob")

* To create an empty blob, upload a zero-length string.
lcResponseStr = loRest.FullRequestString("PUT","/mycontainer/empty.txt","")
IF (loRest.LastMethodSuccess <> 1) THEN
    ? loRest.LastErrorText
    RELEASE loRest
    RELEASE loAzAuth
    CANCEL
ENDIF

* When successful, the Azure Storage service will respond with a 201 response status code,
* with no response body.

IF (loRest.ResponseStatusCode <> 201) THEN
    * Examine the request/response to see what happened.
    ? "response status code = " + STR(loRest.ResponseStatusCode)
    ? "response status text = " + loRest.ResponseStatusText
    ? "response header: " + loRest.ResponseHeader
    ? "response body (if any): " + lcResponseStr
    ? "---"
    ? "LastRequestStartLine: " + loRest.LastRequestStartLine
    ? "LastRequestHeader: " + loRest.LastRequestHeader
    RELEASE loRest
    RELEASE loAzAuth
    CANCEL
ENDIF

? "Success."

RELEASE loRest
RELEASE loAzAuth