本文介绍如何通过 listObjects
列举指定桶下的所有对象、指定前缀文件、指定目录下的文件和子目录。
listObjects
接口已经修订为 listObjectsType2
,强烈建议开发者使用 listObjectsType2
。为保障向后兼容性,TOS 继续支持 listObjects
接口。tos:ListBucket
权限,具体操作,请参见 IAM 策略概述。参数 | 描述 |
---|---|
prefix | 本次查询结果的前缀。 |
delimiter | 对对象名称进行分组的字符。 |
marker | 此次列举对象的起点。 |
encodingType | 对返回的内容进行编码并指定编码的类型。取值说明如下:
|
maxKeys | 返回列举对象的最大数。默认值为 1000。 |
以下代码用于列举指定桶中的 10 个对象。
// 导入 SDK, 当 TOS Node.JS SDK 版本小于 2.5.2 请把下方 TosClient 改成 TOS 导入 import { TosClient, TosClientError, TosServerError } from '@volcengine/tos-sdk'; // 创建客户端 const client = new TosClient({ accessKeyId: process.env['TOS_ACCESS_KEY'], accessKeySecret: process.env['TOS_SECRET_KEY'], region: "Provide your region", // 填写 Bucket 所在地域。以华北2(北京)为例,则 "Provide your region" 填写为 cn-beijing。 endpoint: "Provide your endpoint", // 填写域名地址 }); function handleError(error) { if (error instanceof TosClientError) { console.log('Client Err Msg:', error.message); console.log('Client Err Stack:', error.stack); } else if (error instanceof TosServerError) { console.log('Request ID:', error.requestId); console.log('Response Status Code:', error.statusCode); console.log('Response Header:', error.headers); console.log('Response Err Code:', error.code); console.log('Response Err Msg:', error.message); } else { console.log('unexpected exception, message: ', error); } } const bucketName = 'node-sdk-test-bucket'; async function main() { try { // 获取 bucket 中最多 10 个对象 const { data } = await client.listObjectsType2({ bucket: bucketName, maxKeys: 1000, }); printObjectContents(data.Contents); } catch (error) { handleError(error); } } function printObjectContents(contents) { console.log('Contents Length:', contents.length); for (const obj of contents) { // 对象 Key console.log('Object Key:', obj.Key); // 对象最后修改时间 console.log('Object LastModified:', obj.LastModified); // 对象 Etag console.log('Object ETag:', obj.ETag); // 对象大小 console.log('Object Size:', obj.Size); // 对象 Owner console.log('Object Owner:', obj.Owner); // 对象存储类型 console.log('Object StorageClass:', obj.StorageClass); // 对象 CRC64 console.log('Object HashCrc64ecma:', obj.HashCrc64ecma); } } main();
以下代码用于分页列举指定桶中的对象。
// 导入 SDK, 当 TOS Node.JS SDK 版本小于 2.5.2 请把下方 TosClient 改成 TOS 导入 import { TosClient, TosClientError, TosServerError } from '@volcengine/tos-sdk'; // 创建客户端 const client = new TosClient({ accessKeyId: process.env['TOS_ACCESS_KEY'], accessKeySecret: process.env['TOS_SECRET_KEY'], region: "Provide your region", // 填写 Bucket 所在地域。以华北2(北京)为例,则 "Provide your region" 填写为 cn-beijing。 endpoint: "Provide your endpoint", // 填写域名地址 }); function handleError(error) { if (error instanceof TosClientError) { console.log('Client Err Msg:', error.message); console.log('Client Err Stack:', error.stack); } else if (error instanceof TosServerError) { console.log('Request ID:', error.requestId); console.log('Response Status Code:', error.statusCode); console.log('Response Header:', error.headers); console.log('Response Err Code:', error.code); console.log('Response Err Msg:', error.message); } else { console.log('unexpected exception, message: ', error); } } const bucketName = 'node-sdk-test-bucket'; async function main() { try { // 获取 bucket 中前 1000 个对象 const { data } = await client.listObjects({ bucket: bucketName, maxKeys: 1000, }); printObjectContents(data.Contents); // 分页列举第二页的 1000 个对象 const { data: data2 } = await client.listObjects({ bucket: bucketName, maxKeys: 1000, marker: data.NextMarker, }); printObjectContents(data2.Contents); } catch (error) { handleError(error); } } function printObjectContents(contents) { console.log('Contents Length:', contents.length); for (const obj of contents) { // 对象 Key console.log('Object Key:', obj.Key); // 对象最后修改时间 console.log('Object LastModified:', obj.LastModified); // 对象 Etag console.log('Object ETag:', obj.ETag); // 对象大小 console.log('Object Size:', obj.Size); // 对象 Owner console.log('Object Owner:', obj.Owner); // 对象存储类型 console.log('Object StorageClass:', obj.StorageClass); // 对象 CRC64 console.log('Object HashCrc64ecma:', obj.HashCrc64ecma); } } main();
以下代码用于列举存储桶指定前缀的所有对象。
// 导入 SDK, 当 TOS Node.JS SDK 版本小于 2.5.2 请把下方 TosClient 改成 TOS 导入 import { TosClient, TosClientError, TosServerError } from '@volcengine/tos-sdk'; // 创建客户端 const client = new TosClient({ accessKeyId: process.env['TOS_ACCESS_KEY'], accessKeySecret: process.env['TOS_SECRET_KEY'], region: "Provide your region", // 填写 Bucket 所在地域。以华北2(北京)为例,则 "Provide your region" 填写为 cn-beijing。 endpoint: "Provide your endpoint", // 填写域名地址 }); function handleError(error) { if (error instanceof TosClientError) { console.log('Client Err Msg:', error.message); console.log('Client Err Stack:', error.stack); } else if (error instanceof TosServerError) { console.log('Request ID:', error.requestId); console.log('Response Status Code:', error.statusCode); console.log('Response Header:', error.headers); console.log('Response Err Code:', error.code); console.log('Response Err Msg:', error.message); } else { console.log('unexpected exception, message: ', error); } } const bucketName = 'node-sdk-test-bucket'; async function main() { try { const prefix = '*** Provide your object key prefix ***'; for (let truncated = true, marker = ''; truncated; ) { const { data } = await client.listObjects({ bucket: bucketName, maxKeys: 1000, marker, prefix, }); printObjectContents(data.Contents); truncated = data.IsTruncated; marker = data.NextMarker; } } catch (error) { handleError(error); } } function printObjectContents(contents) { console.log('Contents Length:', contents.length); for (const obj of contents) { // 对象 Key console.log('Object Key:', obj.Key); // 对象最后修改时间 console.log('Object LastModified:', obj.LastModified); // 对象 Etag console.log('Object ETag:', obj.ETag); // 对象大小 console.log('Object Size:', obj.Size); // 对象 Owner console.log('Object Owner:', obj.Owner); // 对象存储类型 console.log('Object StorageClass:', obj.StorageClass); // 对象 CRC64 console.log('Object HashCrc64ecma:', obj.HashCrc64ecma); } } main();
以下代码用于列举指定存储桶中所有对象。
// 导入 SDK, 当 TOS Node.JS SDK 版本小于 2.5.2 请把下方 TosClient 改成 TOS 导入 import { TosClient, TosClientError, TosServerError } from '@volcengine/tos-sdk'; // 创建客户端 const client = new TosClient({ accessKeyId: process.env['TOS_ACCESS_KEY'], accessKeySecret: process.env['TOS_SECRET_KEY'], region: "Provide your region", // 填写 Bucket 所在地域。以华北2(北京)为例,则 "Provide your region" 填写为 cn-beijing。 endpoint: "Provide your endpoint", // 填写域名地址 }); function handleError(error) { if (error instanceof TosClientError) { console.log('Client Err Msg:', error.message); console.log('Client Err Stack:', error.stack); } else if (error instanceof TosServerError) { console.log('Request ID:', error.requestId); console.log('Response Status Code:', error.statusCode); console.log('Response Header:', error.headers); console.log('Response Err Code:', error.code); console.log('Response Err Msg:', error.message); } else { console.log('unexpected exception, message: ', error); } } const bucketName = 'node-sdk-test-bucket'; async function main() { try { for (let truncated = true, marker = ''; truncated; ) { const { data } = await client.listObjects({ bucket: bucketName, maxKeys: 1000, marker, }); printObjectContents(data.Contents); truncated = data.IsTruncated; marker = data.NextMarker; } } catch (error) { handleError(error); } } function printObjectContents(contents) { console.log('Contents Length:', contents.length); for (const obj of contents) { // 对象 Key console.log('Object Key:', obj.Key); // 对象最后修改时间 console.log('Object LastModified:', obj.LastModified); // 对象 Etag console.log('Object ETag:', obj.ETag); // 对象大小 console.log('Object Size:', obj.Size); // 对象 Owner console.log('Object Owner:', obj.Owner); // 对象存储类型 console.log('Object StorageClass:', obj.StorageClass); // 对象 CRC64 console.log('Object HashCrc64ecma:', obj.HashCrc64ecma); } } main();
TOS 只有对象的概念, 可通过创建一个大小为 0 并且以斜线 /
结尾的对象, 模拟目录的功能。 通过 delimiter
和 prefix
两个参数可以模拟目录的功能:
delimiter
为 /
同时设置 prefix
为空, 可返回根目录下的对象和子目录信息。delimiter
为 /
同时设置 prefix
为子目录(subfiledir), 可返回子目录的对象和次级目录。以下代码用于列举存储桶指定目录下的对象和子目录。
// 导入 SDK, 当 TOS Node.JS SDK 版本小于 2.5.2 请把下方 TosClient 改成 TOS 导入 import { TosClient, TosClientError, TosServerError } from '@volcengine/tos-sdk'; // 创建客户端 const client = new TosClient({ accessKeyId: process.env['TOS_ACCESS_KEY'], accessKeySecret: process.env['TOS_SECRET_KEY'], region: "Provide your region", // 填写 Bucket 所在地域。以华北2(北京)为例,则 "Provide your region" 填写为 cn-beijing。 endpoint: "Provide your endpoint", // 填写域名地址 }); function handleError(error) { if (error instanceof TosClientError) { console.log('Client Err Msg:', error.message); console.log('Client Err Stack:', error.stack); } else if (error instanceof TosServerError) { console.log('Request ID:', error.requestId); console.log('Response Status Code:', error.statusCode); console.log('Response Header:', error.headers); console.log('Response Err Code:', error.code); console.log('Response Err Msg:', error.message); } else { console.log('unexpected exception, message: ', error); } } const bucketName = 'node-sdk-test-bucket'; async function main() { try { // 列举目录下的文件和子目录 for (let truncated = true, marker = ''; truncated; ) { const { data } = await client.listObjects({ bucket: bucketName, maxKeys: 1000, marker, delimiter: '/', }); console.log('Sub Dir Length:', data.CommonPrefixes.length); for (const prefix of data.CommonPrefixes) { console.log('Sub Dir:', prefix.Prefix); } printObjectContents(data.Contents); truncated = data.IsTruncated; marker = data.NextMarker; } } catch (error) { handleError(error); } } function printObjectContents(contents) { console.log('Contents Length:', contents.length); for (const obj of contents) { // 对象 Key console.log('Object Key:', obj.Key); // 对象最后修改时间 console.log('Object LastModified:', obj.LastModified); // 对象 Etag console.log('Object ETag:', obj.ETag); // 对象大小 console.log('Object Size:', obj.Size); // 对象 Owner console.log('Object Owner:', obj.Owner); // 对象存储类型 console.log('Object StorageClass:', obj.StorageClass); // 对象 CRC64 console.log('Object HashCrc64ecma:', obj.HashCrc64ecma); } } main();
关于列举对象的 API 文档,请参见 ListObjects。