存储空间(Bucket)是用来存储对象(Object)的容器。对象都隶属于存储空间。存储空间按照字母顺序排列。您可以列举当前账号所有地域下符合指定条件的存储空间。
注意事项
本文示例代码以华东1(杭州)的地域ID
cn-hangzhou为例,默认使用外网Endpoint,如果您希望通过与OSS同地域的其他阿里云产品访问OSS,请使用内网Endpoint。关于OSS支持的Region与Endpoint的对应关系,请参见OSS地域和访问域名。要列举存储空间,您必须具有
oss:ListBuckets权限。具体操作,请参见为RAM用户授予自定义的权限策略。
列举所有存储空间
以下代码用于列举当前账号所有地域下的存储空间。
import AlibabaCloudOSS
import Foundation
@main
struct Main {
    static func main() async {
        do {
            // 填写Bucket所在地域。以华东1(杭州)为例,Region填写为cn-hangzhou。
            let region = "cn-hangzhou"
            // 可选项,指定访问OSS服务的域名。以华东1(杭州)为例,Endpoint填写为https://oss-cn-hangzhou.aliyuncs.com
            let endpoint: String? = nil
            // 从环境变量加载凭证(需提前设置 OSS_ACCESS_KEY_ID 和 OSS_ACCESS_KEY_SECRET)
            let credentialsProvider = EnvironmentCredentialsProvider()
            // 配置OSS客户端参数
            let config = Configuration.default()
                .withRegion(region) // 设置区域
                .withCredentialsProvider(credentialsProvider) // 设置凭证
                
            // 设置Endpoint
            if let endpoint = endpoint {
                config.withEndpoint(endpoint)
            }
            // 创建OSS客户端实例
            let client = Client(config)
            // 创建分页遍历存储空间(Bucket)的Paginator
            let paginator = client.listBucketsPaginator(ListBucketsRequest())
            // 遍历所有存储空间并输出信息
            for try await page in paginator {
                for bucket in page.buckets ?? [] {
                    print("Bucket名称: \(bucket.name ?? ""), 存储类型: \(bucket.storageClass ?? ""), 所属地域: \(bucket.location ?? "")")
                }
            }
        } catch {
            // 捕获并处理异常
            print("error:\n\(error)")
        }
    }
}
相关文档
关于列举存储空间的完整示例代码,请参见GitHub示例。
关于列举存储空间的API接口说明,请参见ListBuckets(GetService)。
该文章对您有帮助吗?