更新时间:2024-06-21 gmt 08:00

创建桶-九游平台

开发过程中,您有任何问题可以在github上,或者在中发帖求助。详细介绍了每个接口的参数和使用方法。

您可以通过obsclient.createbucket创建桶。

带参数创建

创建桶时可以指定桶的访问权限、存储类型和区域位置。obs支持的桶的存储类型有三类,参见。示例代码如下:

// 认证用的ak和sk硬编码到代码中或者明文存储都有很大的安全风险,建议在配置文件或者环境变量中密文存放,使用时解密,确保安全;本示例以ak和sk保存在环境变量中为例,运行本示例前请先在本地环境中设置环境变量access_key_id和secret_access_key_id。
// 您可以登录访问管理控制台获取访问密钥ak/sk,获取方式请参见https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html
string ak = system.getenv("access_key_id");
string sk = system.getenv("secret_access_key_id");
string endpoint = "https://your-endpoint";
// 创建obsclient实例
obsclient obsclient = new obsclient(ak, sk, endpoint);
obsbucket obsbucket = new obsbucket();
obsbucket.setbucketname("bucketname");
// 设置桶访问权限为公共读,默认是私有读写
obsbucket.setacl(accesscontrollist.rest_canned_public_read);
// 设置桶的存储类型为归档存储
obsbucket.setbucketstorageclass(storageclassenum.cold);
// 设置桶区域位置
obsbucket.setlocation("bucketlocation");
// 创建桶
try{
    // 创建桶成功
    headerresponse response =obsclient.createbucket(obsbucket);
    log.i("createbucket", response.getrequestid());
}
catch (obsexception e)
{
    // 创建桶失败
    log.e("createbucket", "response code: "   e.getresponsecode());
    log.e("createbucket", "error message: "   e.geterrormessage());
    log.e("createbucket", "error code:       "   e.geterrorcode());
    log.e("createbucket", "request id:      "   e.geterrorrequestid());
    log.e("createbucket", "host id:           "   e.geterrorhostid());
}

简单创建

以下代码展示如何新建一个桶:

// 认证用的ak和sk硬编码到代码中或者明文存储都有很大的安全风险,建议在配置文件或者环境变量中密文存放,使用时解密,确保安全;本示例以ak和sk保存在环境变量中为例,运行本示例前请先在本地环境中设置环境变量access_key_id和secret_access_key_id。
// 您可以登录访问管理控制台获取访问密钥ak/sk,获取方式请参见https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html
string ak = system.getenv("access_key_id");
string sk = system.getenv("secret_access_key_id");
string endpoint = "https://your-endpoint";
// 创建obsclient实例
obsclient obsclient = new obsclient(ak, sk, endpoint);
// 创建桶
try{
    // 创建桶成功
    headerresponse response = obsclient.createbucket("bucketname");
    log.i("createbucket", response.getrequestid());
}
catch (obsexception e)
{
    // 创建桶失败
    log.e("createbucket", "response code: "   e.getresponsecode());
    log.e("createbucket", "error message: "   e.geterrormessage());
    log.e("createbucket", "error code:       "   e.geterrorcode());
    log.e("createbucket", "request id:      "   e.geterrorrequestid());
    log.e("createbucket", "host id:           "   e.geterrorhostid());
}
  • 桶的名字是全局唯一的,所以您需要确保不与已有的桶名称重复。
  • 桶命名规则如下:
    • 3~63个字符,数字或字母开头,支持小写字母、数字、“-”、“.”。
    • 禁止使用类ip地址。
    • 禁止以“-”或“.”开头及结尾。
    • 禁止两个“.”相邻(如:“my..bucket”)。
    • 禁止“.”和“-”相邻(如:“my-.bucket”和“my.-bucket”)。
  • 同一用户在同一区域多次创建同名桶不会报错,创建的桶属性以第一次请求为准。
  • 本示例创建的桶的默认是私有读写,存储类型默认是标准类型,区域位置是默认区域。
  • 创建桶时,如果使用的终端节点归属于默认区域华北-北京一(cn-north-1),则可以不指定区域;如果使用的终端节点归属于其他区域,则必须指定区域,且指定的区域必须与终端节点归属的区域一致。当前有效的区域名称可从查询。
  • 您可以使用带参数创建方式,在创建桶时,指定桶的区域位置。

相关文档

网站地图