以程式設計方式列出物件索引鍵 - Amazon Simple Storage Service

本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。

以程式設計方式列出物件索引鍵

在 Amazon S3 中,索引鍵可以依字首列出。您可以為相關索引鍵名稱選擇共用字首,並使用特殊字元標示這些索引鍵,以劃分層次結構。然後,您可以使用清單操作,以階層方式選取和瀏覽索引鍵。類似於檔案存放在檔案系統目錄中的方式。

Amazon S3 提供清單操作,讓您可以列舉儲存貯體中所包含的金鑰。這些金鑰會依儲存貯體及字首選取列出。例如,假設有一個名為 "dictionary" 的儲存貯體,其中包含一個代表所有英文文字的索引鍵。您可以進行呼叫,列出該儲存貯體中以字母 "q" 開頭的所有金鑰。清單結果一律以 UTF-8 二進位順序傳回。

SOAP 和 REST 清單操作都會傳回 XML 文件,其中包含相符金鑰的名稱,以及每個金鑰所識別物件的相關資訊。

注意

透過 HTTP 的 SOAP 支援已棄用,但 SOAP 仍可透過 HTTPS 使用。SOAP 不支援新的 Amazon S3 功能。SOAP我們建議您使用 REST 或 API,而不是使用 AWS SDKs。

皆為同一個字首並以特殊分隔符號結尾的金鑰群組,可依該共同字首彙總以方便列出。應用程式如此即可用階層方式組織及瀏覽其金鑰,就像是將檔案分組到檔案系統中不同的目錄一樣。

例如,若要展開 dictionary 儲存貯體以包含英文以外的文字時,可以在每個字前面加上其語言和分隔符號 (例如 "French/logical") 來組成索引鍵。使用此命名配置和階層式清單功能,您就可以只擷取法文文字清單。您也可以瀏覽最上層的可用語言清單,而無須逐一查看詞典編纂的所有金鑰。如需列出清單方面的詳細資訊,請參閱「使用字首整理物件」。

REST API

如果您的應用程式需要,您可以直接傳送 REST 請求。您可以傳送 GET 請求來傳回儲存貯體中的部分或全部物件,也可以使用選取條件來傳回儲存貯體中的物件子集。如需詳細資訊,請參閱 Amazon Simple Storage Service GET 參考中的 Word 儲存貯體 (列出物件) 第 2 版 API

清單實作效率

清單效能不會受儲存貯體中的索引鍵總數所影響。它也不會受到 prefixmarkermaxkeysdelimiter 引數的存在或不存在的影響。

逐一查看多頁結果

因為儲存貯體幾乎可以包含不限數目的金鑰,所以完整的清單查詢結果可能會相當龐大。若要管理大型結果集,Amazon S3 API 支援分頁,以將其分割成多個回應。每個列出金鑰回應最多會傳回含有 1,000 個金鑰的頁面,並指出回應是否遭到截斷。您會傳送一系列清單金鑰請求,直到您收到所有金鑰為止。 AWS SDK 包裝程式庫提供相同的分頁。

範例

列出儲存貯體中的所有物件時請注意,您必須擁有 s3:ListBucket 許可。

CLI
list-objects

下列範例使用 list-objects命令來顯示指定儲存貯體中所有物件的名稱:

aws s3api list-objects --bucket text-content --query 'Contents[].{Key: Key, Size: Size}'

此範例使用 --query 引數,將 的輸出list-objects篩選為每個物件的鍵值和大小

如需物件的詳細資訊,請參閱 Amazon S3 開發人員指南中的使用 Amazon S3 物件。

  • 如需 API 詳細資訊,請參閱 AWS CLI 命令參考中的 ListObjects

ls

下列範例使用 ls命令列出儲存貯體中的所有物件和字首。

若要使用此範例命令,請取代 amzn-s3-demo-bucket 儲存貯體的名稱。

$ aws s3 ls s3://amzn-s3-demo-bucket
PowerShell
for PowerShell 工具

範例 1:此命令會擷取儲存貯體 "test-files" 中所有項目的相關資訊。

Get-S3Object -BucketName amzn-s3-demo-bucket

範例 2:此命令會從儲存貯體 "test-files" 擷取項目 "sample.txt" 的相關資訊。

Get-S3Object -BucketName amzn-s3-demo-bucket -Key sample.txt

範例 3:此命令會從儲存貯體 "test-files" 擷取具有字首 "sample" 的所有項目的相關資訊。

Get-S3Object -BucketName amzn-s3-demo-bucket -KeyPrefix sample
  • 如需 API 詳細資訊,請參閱 AWS Tools for PowerShell Cmdlet 參考中的 ListObjects