简介
本文档提供关于存储桶标签的 API 概览以及 SDK 示例代码。
PUT Bucket tagging |
设置存储桶标签 |
为已存在的存储桶设置标签 |
GET Bucket tagging |
查询存储桶标签 |
查询指定存储桶下已有的存储桶标签 |
DELETE Bucket tagging |
删除存储桶标签 |
删除指定的存储桶标签 |
设置存储桶标签
功能说明
PUT Bucket tagging 用于为已存在的存储桶设置标签。
方法原型
cos_status_t *cos_put_bucket_tagging(const cos_request_options_t *options, const cos_string_t *bucket, cos_tagging_params_t *tagging_params, cos_table_t **resp_headers);
请求示例
#include "cos_http_io.h"#include "cos_api.h"#include "cos_log.h"#include
static char TEST_COS_ENDPOINT[] = "cos.ap-guangzhou.myqcloud.com";static char *TEST_ACCESS_KEY_ID; static char *TEST_ACCESS_KEY_SECRET; static char TEST_APPID[] = ""; static char TEST_BUCKET_NAME[] = "";
void log_status(cos_status_t *s){ cos_warn_log("status->code: %d", s->code); if (s->error_code) cos_warn_log("status->error_code: %s", s->error_code); if (s->error_msg) cos_warn_log("status->error_msg: %s", s->error_msg); if (s->req_id) cos_warn_log("status->req_id: %s", s->req_id);}
void init_test_config(cos_config_t *config, int is_cname){ cos_str_set(&config->endpoint, TEST_COS_ENDPOINT); cos_str_set(&config->access_key_id, TEST_ACCESS_KEY_ID); cos_str_set(&config->access_key_secret, TEST_ACCESS_KEY_SECRET); cos_str_set(&config->appid, TEST_APPID); config->is_cname = is_cname;}
void init_test_request_options(cos_request_options_t *options, int is_cname){ options->config = cos_config_create(options->pool); init_test_config(options->config, is_cname); options->ctl = cos_http_controller_create(options->pool, 0);}
void test_put_bucket_tagging(){ cos_pool_t *pool = NULL; int is_cname = 0; cos_status_t *status = NULL; cos_request_options_t *options = NULL; cos_table_t *resp_headers = NULL; cos_string_t bucket; cos_tagging_params_t *params = NULL; cos_tagging_tag_t *tag = NULL;
cos_pool_create(&pool, NULL);
options = cos_request_options_create(pool); init_test_request_options(options, is_cname); cos_str_set(&bucket, TEST_BUCKET_NAME);
params = cos_create_tagging_params(pool); tag = cos_create_tagging_tag(pool); cos_str_set(&tag->key, "age"); cos_str_set(&tag->value, "18"); cos_list_add_tail(&tag->node, ¶ms->node);
tag = cos_create_tagging_tag(pool); cos_str_set(&tag->key, "name"); cos_str_set(&tag->value, "xiaoming"); cos_list_add_tail(&tag->node, ¶ms->node);
status = cos_put_bucket_tagging(options, &bucket, params, &resp_headers); log_status(status);
cos_pool_destroy(pool);}
int main(int argc, char *argv[]){ TEST_ACCESS_KEY_ID = getenv("COS_SECRETID"); TEST_ACCESS_KEY_SECRET = getenv("COS_SECRETKEY");
if (cos_http_io_initialize(NULL, 0) != COSE_OK) { exit(1); }
cos_log_set_level(COS_LOG_WARN);
cos_log_set_output(NULL);
test_put_bucket_tagging();
cos_http_io_deinitialize();
return 0;}
参数说明
options |
COS 请求选项 |
Struct |
bucket |
设置标签的存储桶,格式为 BucketName-APPID ,详情请参见 命名规范 |
String |
tagging_params |
存储桶标签配置信息 |
Struct |
key |
标签的 Key,长度不超过128字节, 支持英文字母、数字、空格、加号、减号、下划线、等号、点号、冒号、斜线 |
String |
value |
标签的 Value,长度不超过256字节, 支持英文字母、数字、空格、加号、减号、下划线、等号、点号、冒号、斜线 |
String |
resp_headers |
返回 HTTP 响应消息的头域 |
Struct |
返回结果说明
code |
错误码 |
Int |
error_code |
错误码内容 |
String |
error_msg |
错误码描述 |
String |
req_id |
请求消息 ID |
String |
查询存储桶标签
功能说明
GET Bucket tagging 用于查询指定存储桶下已有的存储桶标签。
方法原型
cos_status_t *cos_get_bucket_tagging(const cos_request_options_t *options, const cos_string_t *bucket, cos_tagging_params_t *tagging_params, cos_table_t **resp_headers);
请求示例
#include "cos_http_io.h"#include "cos_api.h"#include "cos_log.h"#include
static char TEST_COS_ENDPOINT[] = "cos.ap-guangzhou.myqcloud.com";static char *TEST_ACCESS_KEY_ID; static char *TEST_ACCESS_KEY_SECRET; static char TEST_APPID[] = ""; static char TEST_BUCKET_NAME[] = "";
void log_status(cos_status_t *s){ cos_warn_log("status->code: %d", s->code); if (s->error_code) cos_warn_log("status->error_code: %s", s->error_code); if (s->error_msg) cos_warn_log("status->error_msg: %s", s->error_msg); if (s->req_id) cos_warn_log("status->req_id: %s", s->req_id);}
void init_test_config(cos_config_t *config, int is_cname){ cos_str_set(&config->endpoint, TEST_COS_ENDPOINT); cos_str_set(&config->access_key_id, TEST_ACCESS_KEY_ID); cos_str_set(&config->access_key_secret, TEST_ACCESS_KEY_SECRET); cos_str_set(&config->appid, TEST_APPID); config->is_cname = is_cname;}
void init_test_request_options(cos_request_options_t *options, int is_cname){ options->config = cos_config_create(options->pool); init_test_config(options->config, is_cname); options->ctl = cos_http_controller_create(options->pool, 0);}
void test_get_bucket_tagging(){ cos_pool_t *pool = NULL; int is_cname = 0; cos_status_t *status = NULL; cos_request_options_t *options = NULL; cos_table_t *resp_headers = NULL; cos_string_t bucket; cos_tagging_params_t *result = NULL; cos_tagging_tag_t *tag = NULL;
cos_pool_create(&pool, NULL);
options = cos_request_options_create(pool); init_test_request_options(options, is_cname); cos_str_set(&bucket, TEST_BUCKET_NAME);
result = cos_create_tagging_params(pool); status = cos_get_bucket_tagging(options, &bucket, result, &resp_headers); log_status(status);
tag = NULL; cos_list_for_each_entry(cos_tagging_tag_t, tag, &result->node, node) { printf("taging key: %s\n", tag->key.data); printf("taging value: %s\n", tag->value.data);
}
cos_pool_destroy(pool);}
int main(int argc, char *argv[]){ TEST_ACCESS_KEY_ID = getenv("COS_SECRETID"); TEST_ACCESS_KEY_SECRET = getenv("COS_SECRETKEY");
if (cos_http_io_initialize(NULL, 0) != COSE_OK) { exit(1); }
cos_log_set_level(COS_LOG_WARN);
cos_log_set_output(NULL);
test_get_bucket_tagging();
cos_http_io_deinitialize();
return 0;}
参数说明
options |
COS 请求选项 |
Struct |
bucket |
查询标签的存储桶,格式为 BucketName-APPID ,详情请参见 命名规范 |
String |
tagging_params |
存储桶标签配置信息 |
Struct |
key |
标签的 Key,长度不超过128字节, 支持英文字母、数字、空格、加号、减号、下划线、等号、点号、冒号、斜线 |
String |
value |
标签的 Value,长度不超过256字节, 支持英文字母、数字、空格、加号、减号、下划线、等号、点号、冒号、斜线 |
String |
resp_headers |
返回 HTTP 响应消息的头域 |
Struct |
返回结果说明
code |
错误码 |
Int |
error_code |
错误码内容 |
String |
error_msg |
错误码描述 |
String |
req_id |
请求消息 ID |
String |
删除存储桶标签
功能说明
DELETE Bucket tagging 用于删除指定存储桶下已有的存储桶标签。
方法原型
cos_status_t *cos_delete_bucket_tagging(const cos_request_options_t *options, const cos_string_t *bucket, cos_table_t **resp_headers);
请求示例
#include "cos_http_io.h"#include "cos_api.h"#include "cos_log.h"#include
static char TEST_COS_ENDPOINT[] = "cos.ap-guangzhou.myqcloud.com";static char *TEST_ACCESS_KEY_ID; static char *TEST_ACCESS_KEY_SECRET; static char TEST_APPID[] = ""; static char TEST_BUCKET_NAME[] = "";
void log_status(cos_status_t *s){ cos_warn_log("status->code: %d", s->code); if (s->error_code) cos_warn_log("status->error_code: %s", s->error_code); if (s->error_msg) cos_warn_log("status->error_msg: %s", s->error_msg); if (s->req_id) cos_warn_log("status->req_id: %s", s->req_id);}
void init_test_config(cos_config_t *config, int is_cname){ cos_str_set(&config->endpoint, TEST_COS_ENDPOINT); cos_str_set(&config->access_key_id, TEST_ACCESS_KEY_ID); cos_str_set(&config->access_key_secret, TEST_ACCESS_KEY_SECRET); cos_str_set(&config->appid, TEST_APPID); config->is_cname = is_cname;}
void init_test_request_options(cos_request_options_t *options, int is_cname){ options->config = cos_config_create(options->pool); init_test_config(options->config, is_cname); options->ctl = cos_http_controller_create(options->pool, 0);}
void test_delete_bucket_tagging(){ cos_pool_t *pool = NULL; int is_cname = 0; cos_status_t *status = NULL; cos_request_options_t *options = NULL; cos_table_t *resp_headers = NULL; cos_string_t bucket;
cos_pool_create(&pool, NULL);
options = cos_request_options_create(pool); init_test_request_options(options, is_cname); cos_str_set(&bucket, TEST_BUCKET_NAME);
status = cos_delete_bucket_tagging(options, &bucket, &resp_headers); log_status(status);
cos_pool_destroy(pool);}
int main(int argc, char *argv[]){ TEST_ACCESS_KEY_ID = getenv("COS_SECRETID"); TEST_ACCESS_KEY_SECRET = getenv("COS_SECRETKEY");
if (cos_http_io_initialize(NULL, 0) != COSE_OK) { exit(1); }
cos_log_set_level(COS_LOG_WARN);
cos_log_set_output(NULL);
test_delete_bucket_tagging();
cos_http_io_deinitialize();
return 0;}
参数说明
options |
COS 请求选项 |
Struct |
bucket |
被删除标签的存储桶,格式为 BucketName-APPID ,详情请参见 命名规范 |
String |
resp_headers |
返回 HTTP 响应消息的头域 |
Struct |
返回结果说明
code |
错误码 |
Int |
error_code |
错误码内容 |
String |
error_msg |
错误码描述 |
String |
req_id |
请求消息 ID |
String |
对象存储官网1折活动,限时活动,即将结束,速速收藏
同尘科技为腾讯云授权服务中心。
购买腾讯云产品享受折上折,更有现金返利。同意关联立享优惠
转转请注明出处:https://www.yunxiaoer.com/145457.html