tencent cloud

文档反馈

创建存储桶

最后更新时间:2024-01-05 17:20:37

    简介

    本文档提供关于创建存储桶的 API 概览以及 SDK 示例代码。
    注意
    建议用户 使用临时密钥 调用 SDK,通过临时授权的方式进一步提高 SDK 使用的安全性。申请临时密钥时,请遵循 最小权限指引原则,防止泄露目标存储桶或对象之外的资源。
    如果您一定要使用永久密钥,建议遵循 最小权限指引原则 对永久密钥的权限范围进行限制。
    API
    操作名
    操作描述
    创建存储桶
    在指定账号下创建一个存储桶

    创建存储桶

    功能说明

    在指定账号下创建一个存储桶。同一用户账号下,可以创建多个存储桶,数量上限是200个(不区分地域),存储桶中的对象数量没有限制。创建存储桶是低频操作,一般建议在控制台创建 Bucket,在 SDK 进行 Object 的操作。

    方法原型

    func (s *BucketService) Put(ctx context.Context, opt *BucketPutOptions) (*Response, error)

    请求示例

    package main
    
    import (
    "context"
    "github.com/tencentyun/cos-go-sdk-v5"
    "net/http"
    "net/url"
    "os"
    )
    
    func main() {
    // 存储桶名称,由 bucketname-appid 组成,appid 必须填入,可以在 COS 控制台查看存储桶名称。 https://console.tencentcloud.com/cos5/bucket
    // 替换为用户的 region,存储桶 region 可以在 COS 控制台“存储桶概览”查看 https://console.tencentcloud.com/ ,关于地域的详情见 https://www.tencentcloud.com/document/product/436/6224?from_cn_redirect=1 。
    u, _ := url.Parse("https://examplebucket-1250000000.cos.ap-guangzhou.myqcloud.com")
    b := &cos.BaseURL{BucketURL: u}
    client := cos.NewClient(b, &http.Client{
    Transport: &cos.AuthorizationTransport{
    // 通过环境变量获取密钥
    // 环境变量 SECRETID 表示用户的 SecretId,登录访问管理控制台查看密钥,https://console.tencentcloud.com/cam/capi
    SecretID: os.Getenv("SECRETID"), // 用户的 SecretId,建议使用子账号密钥,授权遵循最小权限指引,降低使用风险。子账号密钥获取可参见 https://www.tencentcloud.com/document/product/598/37140?from_cn_redirect=1
    // 环境变量 SECRETKEY 表示用户的 SecretKey,登录访问管理控制台查看密钥,https://console.tencentcloud.com/cam/capi
    SecretKey: os.Getenv("SECRETKEY"), // 用户的 SecretKey,建议使用子账号密钥,授权遵循最小权限指引,降低使用风险。子账号密钥获取可参见 https://www.tencentcloud.com/document/product/598/37140?from_cn_redirect=1
    },
    })
    
    // case1:创建存储桶
    opt := &cos.BucketPutOptions{
    XCosACL: "private",
    }
    _, err := client.Bucket.Put(context.Background(), opt)
    if err != nil {
    panic(err)
    }
    
    // case2:创建 MAZ 存储桶
    opt.CreateBucketConfiguration = &cos.CreateBucketConfiguration{
    BucketAZConfig: "MAZ",
    }
    _, err = client.Bucket.Put(context.Background(), opt)
    if err != nil {
    panic(err)
    }
    }

    参数说明

    type BucketPutOptions struct {
    XCosACL string
    XCosGrantRead string
    XCosGrantWrite string
    XCosGrantFullControl string
    CreateBucketConfiguration *CreateBucketConfiguration
    }
    type CreateBucketConfiguration struct {
    BucketAZConfig string
    }
    参数名称
    参数描述
    类型
    是否必填
    XCosACL
    设置 Bucket 的 ACL,如 private,public-read,public-read-write
    string
    XCosGrantFullControl
    赋予指定账户对 Bucket 的读写权限。格式为 id=" ",id=" "。当需要给子账户授权时,格式为 id="qcs::cam::uin/{OwnerUin}:uin/{SubUin}",当需要给主账户授权时,格式为 id="qcs::cam::uin/{OwnerUin}:uin/{OwnerUin}"。例如id="qcs::cam::uin/100000000001:uin/100000000011",id="qcs::cam::uin/100000000001:uin/100000000001"
    string
    XCosGrantRead
    赋予指定账户对 Bucket 的读权限。格式为 id=" ",id=" "。当需要给子账户授权时,格式为 id="qcs::cam::uin/{OwnerUin}:uin/{SubUin}",当需要给主账户授权时,格式为 id="qcs::cam::uin/{OwnerUin}:uin/{OwnerUin}"。例如id="qcs::cam::uin/100000000001:uin/100000000011",id="qcs::cam::uin/100000000001:uin/100000000001"
    string
    XCosGrantWrite
    赋予指定账户对 Bucket 的写权限。格式为id=" ",id=" "。当需要给子账户授权时,格式为 id="qcs::cam::uin/{OwnerUin}:uin/{SubUin}",当需要给主账户授权时,格式为 id="qcs::cam::uin/{OwnerUin}:uin/{OwnerUin}"。例如 id="qcs::cam::uin/100000000001:uin/100000000011",id="qcs::cam::uin/100000000001:uin/100000000001"
    string
    BucketAZConfig
    存储桶 AZ 配置,指定为 MAZ 以创建多 AZ 存储桶。多 AZ 存储类型的适用地域,请参见 多 AZ 特性概述
    Struct
    
    联系我们

    联系我们,为您的业务提供专属服务。

    技术支持

    如果你想寻求进一步的帮助,通过工单与我们进行联络。我们提供7x24的工单服务。

    7x24 电话支持