Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Ruby) S3 Get Bucket Objects with CommonPrefixesDemonstrates how to get a list of bucket objects using the prefix and delimiter query params to get an XML result with CommonPrefixes.
require 'chilkat' # This example assumes the Chilkat HTTP API to have been previously unlocked. # See Global Unlock Sample for sample code. http = Chilkat::CkHttp.new() # Insert your access key here: http.put_AwsAccessKey("AWS_ACCESS_KEY") # Insert your secret key here: http.put_AwsSecretKey("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 strXml = http.s3_ListBucketObjects("chilkat100?prefix=images/&delimiter=/") if (http.get_LastMethodSuccess() != true) print http.lastErrorText() + "\n"; exit end print "Response status code = " + http.get_LastStatus().to_s() + "\n"; xml = Chilkat::CkXml.new() success = xml.LoadXml(strXml) if (success != true) print xml.lastErrorText() + "\n"; exit end # 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) print xml.getXml() + "\n"; print "Failed." + "\n"; exit end # A sample response is shown below. print xml.getXml() + "\n"; print "----" + "\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> # The XML can be parsed like this: i = 0 count_i = xml.NumChildrenHavingTag("CommonPrefixes") while i < count_i xml.put_I(i) Prefix = xml.getChildContent("CommonPrefixes[i]|Prefix") print "Prefix = " + Prefix + "\n"; i = i + 1 end |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.