Sample code for 30+ languages & platforms
Unicode C++

S3 Get Bucket Objects with CommonPrefixes

See more Amazon S3 Examples

Demonstrates how to get a list of bucket objects using the prefix and delimiter query params to get an XML result with CommonPrefixes.

Chilkat Unicode C++ Downloads

Unicode C++
#include <CkHttpW.h>
#include <CkXmlW.h>

void ChilkatSample(void)
    {
    bool success = false;

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

    CkHttpW http;

    // Insert your access key here:
    http.put_AwsAccessKey(L"AWS_ACCESS_KEY");

    // Insert your secret key here:
    http.put_AwsSecretKey(L"AWS_SECRET_KEY");

    // In this example, my bucket is "chilkat100".
    // It contains a number of folders, one of which is named "images".
    // I want to get a list of all sub-folders under the "images" folder
    const wchar_t *strXml = http.s3_ListBucketObjects(L"chilkat100?prefix=images/&delimiter=/");
    if (http.get_LastMethodSuccess() != true) {
        wprintf(L"%s\n",http.lastErrorText());
        return;
    }

    wprintf(L"Response status code = %d\n",http.get_LastStatus());

    CkXmlW xml;
    success = xml.LoadXml(strXml);
    if (success != true) {
        wprintf(L"%s\n",xml.lastErrorText());
        return;
    }

    // If the response status code was not 200, then the XML response is not a 
    // listing of objects, but instead contains error information.
    if (http.get_LastStatus() != 200) {
        wprintf(L"%s\n",xml.getXml());
        wprintf(L"Failed.\n");
        return;
    }

    // A sample response is shown below.
    wprintf(L"%s\n",xml.getXml());
    wprintf(L"----\n");

    // Here is the list of sub-folders (i.e. CommonPrefixes)

    // <?xml version="1.0" encoding="UTF-8"?>
    // <ListBucketResult xmlns="http://s3.amazonaws.com/doc/2006-03-01/">
    //     <Name>chilkat100</Name>
    //     <Prefix>images/</Prefix>
    //     <Marker/>
    //     <MaxKeys>1000</MaxKeys>
    //     <Delimiter>/</Delimiter>
    //     <IsTruncated>false</IsTruncated>
    //     <CommonPrefixes>
    //         <Prefix>images/africa/</Prefix>
    //     </CommonPrefixes>
    //     <CommonPrefixes>
    //         <Prefix>images/sea_creatures/</Prefix>
    //     </CommonPrefixes>
    // </ListBucketResult>

    const wchar_t *Prefix = 0;

    // The XML can be parsed like this:
    int i = 0;
    int count_i = xml.NumChildrenHavingTag(L"CommonPrefixes");
    while (i < count_i) {
        xml.put_I(i);
        Prefix = xml.getChildContent(L"CommonPrefixes[i]|Prefix");
        wprintf(L"Prefix = %s\n",Prefix);
        i = i + 1;
    }
    }