Sample code for 30+ languages & platforms
C#

REST Asynchronous Streaming Upload File

See more REST Examples

Demonstrates how to asynchronous streaming upload a file to cloud storage. This particular example demonstrates an upload to the Azure Cloud Storage service. The same concepts apply to S3, Google Cloud, and Google Drive.

Chilkat C# Downloads

C#
bool success = false;

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

Chilkat.Rest rest = new Chilkat.Rest();

// Connect to the Azure Storage Blob Service
bool bTls = true;
int port = 443;
bool bAutoReconnect = true;
// In this example, the storage account name is "chilkat".
success = rest.Connect("chilkat.blob.core.windows.net",port,bTls,bAutoReconnect);
if (success != true) {
    Debug.WriteLine(rest.LastErrorText);
    return;
}

// Provide Azure Cloud credentials for the REST call.
Chilkat.AuthAzureStorage azAuth = new Chilkat.AuthAzureStorage();
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(azAuth);

// Set some request headers.
success = rest.AddHeader("x-ms-blob-content-disposition","attachment; filename=\"thisIsATest.txt\"");
success = rest.AddHeader("x-ms-blob-type","BlockBlob");
success = rest.AddHeader("x-ms-meta-m1","v1");
success = rest.AddHeader("x-ms-meta-m2","v2");

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

Chilkat.Stream sendStream = new Chilkat.Stream();

// Define the source data for the stream to be a file.
sendStream.SourceFile = "qa_data/hamlet.xml";

// Create a background thread task to upload from the stream
// The name of the Azure storage container is "test".
Chilkat.Task task = rest.FullRequestStreamAsync("PUT","/test/thisIsATest.txt",sendStream);

// Start the task. 
success = task.Run();

// In this example, we'll simply sleep and periodically
// check to see if the REST upload if finished.
int curPctDone = 0;
while (task.Finished != true) {
    task.SleepMs(100);
}

// Check to see if the call to FullRequestStream in the background thread pool succeeded.
if (task.TaskSuccess != true) {
    // Show what would've been the LastErrorText had FullRequestStream been called synchronously
    Debug.WriteLine(task.ResultErrorText);

    return;
}

int responseStatusCode = rest.ResponseStatusCode;

// When successful, the Azure Storage service will respond with a 201 response code,
// with an empty body.  Therefore, in the success condition, the responseStr is empty.
if (responseStatusCode == 201) {
    Debug.WriteLine("File uploaded.");
}
else {
    // It failed, so examine the response body, if one was returned:
    // Given that FullRequestStream returns a string, the return value is obtained via GetResultString.
    string responseBodyStr = task.GetResultString();
    Debug.WriteLine("response body (if any): " + responseBodyStr);

    // Examine the request/response to see what happened.
    Debug.WriteLine("response status code = " + Convert.ToString(rest.ResponseStatusCode));
    Debug.WriteLine("response status text = " + rest.ResponseStatusText);
    Debug.WriteLine("response header: " + rest.ResponseHeader);
    Debug.WriteLine("---");
    Debug.WriteLine("LastRequestStartLine: " + rest.LastRequestStartLine);
    Debug.WriteLine("LastRequestHeader: " + rest.LastRequestHeader);
}