Sample code for 30+ languages & platforms
Perl

Get Container Properties

See more Azure Cloud Storage Examples

Azure Storage Blob Service REST API: Sample code to get the properties of a container.

Chilkat Perl Downloads

Perl
use chilkat();

$success = 0;

# Azure Blob Service Example: Get Container Properties
# See also: https://msdn.microsoft.com/en-us/library/azure/dd179370.aspx

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

$rest = chilkat::CkRest->new();

# Connect to the Azure Storage Blob Service
$bTls = 1;
$port = 443;
$bAutoReconnect = 1;
# In this example, the storage account name is "chilkat".
$success = $rest->Connect("chilkat.blob.core.windows.net",$port,$bTls,$bAutoReconnect);
if ($success != 1) {
    print $rest->lastErrorText() . "\r\n";
    exit;
}

# Provide Azure Cloud credentials for the REST call.
$azAuth = chilkat::CkAuthAzureStorage->new();
$azAuth->put_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->put_Account("chilkat");
$azAuth->put_Scheme("SharedKey");
$azAuth->put_Service("Blob");
# This causes the "x-ms-version: 2021-08-06" header to be automatically added.
$azAuth->put_XMsVersion("2021-08-06");
$success = $rest->SetAuthAzureStorage($azAuth);

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

# The expected success response is a 200 response status code with no response body.
# In this example, we are getting the properties of the container named "mycontainer".
$responseStr = $rest->fullRequestNoBody("GET","/mycontainer?restype=container");
if ($rest->get_LastMethodSuccess() != 1) {
    print $rest->lastErrorText() . "\r\n";
    exit;
}

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

if ($rest->get_ResponseStatusCode() != 200) {
    # Examine the request/response to see what happened.
    print "response status code = " . $rest->get_ResponseStatusCode() . "\r\n";
    print "response status text = " . $rest->responseStatusText() . "\r\n";
    print "response header: " . $rest->responseHeader() . "\r\n";
    print "response body (if any): " . $responseStr . "\r\n";
    print "---" . "\r\n";
    print "LastRequestStartLine: " . $rest->lastRequestStartLine() . "\r\n";
    print "LastRequestHeader: " . $rest->lastRequestHeader() . "\r\n";
    exit;
}

# The container properties are located in the response header.
# The full response header can be obtained like this:
print "response header: " . $rest->responseHeader() . "\r\n";
print "--" . "\r\n";

# Individual response header fields can be retrieved like this:
print "x-ms-lease-status: " . $rest->responseHdrByName("x-ms-lease-status") . "\r\n";
print "x-ms-lease-state: " . $rest->responseHdrByName("x-ms-lease-state") . "\r\n";

print "Success." . "\r\n";