Sample code for 30+ languages & platforms
Swift

Azure Storage: Upload Binary Data to Block Blob using BinData

See more Azure Cloud Storage Examples

Sample code to upload binary bytes (contained in a Chilkat BinData object) to a block blob in Azure Cloud Storage. This creates the block blob, or replaces an existing block blob.

Note: The maximum size of a block blob created by uploading in a single step is 64MB. For larger files, the upload must be broken up into blocks. There is another Chilkat example for that..

Chilkat Swift Downloads

Swift

func chilkatTest() {
    var success: Bool = false

    // Azure Blob Service Example: Upload binary bytes to a block blob.
    // This creates a new block blob or replaces an existing one in its entirety.
    // 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.

    let rest = CkoRest()!

    // Connect to the Azure Storage Blob Service
    var bTls: Bool = true
    var port: Int = 443
    var bAutoReconnect: Bool = true
    // In this example, the storage account name is "chilkat".
    success = rest.connect(hostname: "chilkat.blob.core.windows.net", port: port, tls: bTls, autoReconnect: bAutoReconnect)
    if success != true {
        print("\(rest.lastErrorText!)")
        return
    }

    // Provide Azure Cloud credentials for the REST call.
    let azAuth = CkoAuthAzureStorage()!
    azAuth.accessKey = "AZURE_ACCESS_KEY"
    // The account name used here should match the 1st part of the domain passed in the call to Connect (above).
    azAuth.account = "chilkat"
    azAuth.scheme = "SharedKey"
    azAuth.service = "Blob"
    // This causes the "x-ms-version: 2021-08-06" header to be automatically added.
    azAuth.xMsVersion = "2021-08-06"
    success = rest.setAuthAzureStorage(authProvider: azAuth)

    // 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:
    success = rest.addHeader(name: "x-ms-blob-type", value: "BlockBlob")

    // For this example, we'll just load a JPG file into memory..
    let bd = CkoBinData()!
    success = bd.loadFile(path: "qa_data/jpg/starfish.jpg")
    if success == false {
        print("Failed to load the file to be uploaded.")
        return
    }

    // Note: The maximum size of a block blob created by uploading in a single step is 64MB.  
    // For larger files, the upload must be broken up into blocks.  There is another Chilkat example for that..
    let sbResponseBody = CkoStringBuilder()!
    success = rest.fullRequestBd(httpVerb: "PUT", uriPath: "/mycontainer/starfish.jpg", binData: bd, responseBody: sbResponseBody)
    if success == false {
        print("\(rest.lastErrorText!)")
        return
    }

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

    if rest.responseStatusCode.intValue != 201 {
        // Examine the request/response to see what happened.
        print("response status code = \(rest.responseStatusCode.intValue)")
        print("response status text = \(rest.responseStatusText!)")
        print("response header: \(rest.responseHeader!)")
        print("response body (if any): \(sbResponseBody.getAsString()!)")
        print("---")
        print("LastRequestStartLine: \(rest.lastRequestStartLine!)")
        print("LastRequestHeader: \(rest.lastRequestHeader!)")
        return
    }

    print("Success.")

}