存储空间(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)。
该文章对您有帮助吗?