详情页标题前

腾讯云对象存储访问控制

详情页1

简介

文档提供关于存储桶、对象的访问控制列表(ACL)的相关 API 概览以及 SDK 示例代码。存储桶 ACL

API 操作名 操作描述
PUT Bucket acl 设置存储桶 ACL 设置指定存储桶的访问权限控制列表(ACL)
GET Bucket acl 查询存储桶 ACL 查询指定存储桶的访问权限控制列表(ACL)

对象 ACL

API 操作名 操作描述
PUT Object acl 设置对象 ACL 设置存储桶中某个对象的访问控制列表
GET Object acl 查询对象 ACL 查询对象的访问控制列表

存储桶 ACL

设置存储桶 ACL

功能说明

PUT Bucket acl 接口用来设置指定存储桶访问权限控制列表(ACL)。

使用示例

设置存储桶公有读:

cos.putBucketAcl({    Bucket: 'examplebucket-1250000000', /* 必须 */    Region: 'COS_REGION',    /* 必须 */    ACL: 'public-read'}, function(err, data) {    console.log(err || data);});

为某个用户赋予存储桶所有权限:

cos.putBucketAcl({    Bucket: 'examplebucket-1250000000', /* 必须 */    Region: 'COS_REGION',    /* 必须 */    GrantFullControl: 'id="qcs::cam::uin/100000000001:uin/100000000001",id="qcs::cam::uin/100000000011:uin/100000000011"' // 100000000001是 uin}, function(err, data) {    console.log(err || data);});

通过 AccessControlPolicy 修改存储桶权限:

cos.putBucketAcl({    Bucket: 'examplebucket-1250000000', /* 必须 */    Region: 'COS_REGION',    /* 必须 */    AccessControlPolicy: {        "Owner": { // AccessControlPolicy 里必须有 owner            "ID": 'qcs::cam::uin/100000000001:uin/100000000001' // 100000000001 是主账号 uin        },        "Grants": [{            "Grantee": {                "ID": "qcs::cam::uin/100000000011:uin/100000000011", // 100000000011 是主账号下的子账号 uin            },            "Permission": "WRITE"        }]    }}, function(err, data) {    console.log(err || data);});

参数说明

参数名 参数描述 类型 是否必填
Bucket 存储桶的名称,命名格式为 BucketName-APPID,此处填写的存储桶名称必须为此格式 String
Region 存储桶所在地域,枚举值请参见 地域和访问域名 String
ACL 定义存储桶的访问控制列表(ACL)属性。枚举值请参见 ACL 概述 文档中存储桶的预设 ACL 部分,例如 private, public-read 等,默认为 private String
GrantRead 赋予被授权者读取存储桶的权限,格式:id=”[OwnerUin]”,可使用半角逗号(,)分隔多组被授权者:当需要给子账号授权时,id="qcs::cam::uin/:uin/"当需要给主账号授权时,id="qcs::cam::uin/:uin/"例如'id="qcs::cam::uin/100000000001:uin/100000000001", id="qcs::cam::uin/100000000001:uin/100000000011"' String
GrantWrite 赋予被授权者写入存储桶的权限,格式:id=”[OwnerUin]”,可使用半角逗号(,)分隔多组被授权者:当需要给子账号授权时,id="qcs::cam::uin/:uin/"当需要给主账号授权时,id="qcs::cam::uin/:uin/"例如'id="qcs::cam::uin/100000000001:uin/100000000001", id="qcs::cam::uin/100000000001:uin/100000000011"' String
GrantReadAcp 赋予被授权者读取存储桶的访问控制列表(ACL)和存储桶策略(Policy)的权限。格式:id=”[OwnerUin]”,可使用半角逗号(,)分隔多组被授权者:当需要给子账号授权时,id="qcs::cam::uin/:uin/"当需要给主账号授权时,id="qcs::cam::uin/:uin/"例如'id="qcs::cam::uin/100000000001:uin/100000000001", id="qcs::cam::uin/100000000001:uin/100000000011"' String
GrantWriteAcp 赋予被授权者写入存储桶的访问控制列表(ACL)和存储桶策略(Policy)的权限。格式:id=”[OwnerUin]”,可使用半角逗号(,)分隔多组被授权者:当需要给子账号授权时,id="qcs::cam::uin/:uin/"当需要给主账号授权时,id="qcs::cam::uin/:uin/"例如'id="qcs::cam::uin/100000000001:uin/100000000001", id="qcs::cam::uin/100000000001:uin/100000000011"' String
GrantFullControl 赋予被授权者操作存储桶的所有权限,格式:id=”[OwnerUin]”,可使用半角逗号(,)分隔多组被授权者:当需要给子账号授权时,id="qcs::cam::uin/:uin/"当需要给主账号授权时,id="qcs::cam::uin/:uin/"例如'id="qcs::cam::uin/100000000001:uin/100000000001", id="qcs::cam::uin/100000000001:uin/100000000011"' String
AccessControlPolicy 跨域资源共享配置的所有信息列表 Object
– Owner 存储桶持有者的信息 Object
– – ID 存储桶持有者的完整 ID,格式为qcs::cam::uin/[OwnerUin]:uin/[OwnerUin]例如qcs::cam::uin/100000000001:uin/100000000001,其中100000000001为 uin String
– Grants 被授权者信息与权限信息列表 ObjectArray
– – Permission 授予的权限信息,可选项 READ、WRITE、READ_ACP、WRITE_ACP、FULL_CONTROL。枚举值详情参见 ACL 概述 文档中存储桶的操作部分 String
– – Grantee 被授权者的信息 Object
– – – ID 被授权者的完整 ID,格式为qcs::cam::uin/[OwnerUin]:uin/[OwnerUin]例如qcs::cam::uin/100000000001:uin/100000000001,其中100000000001为 uin String
– – – DisplayName 被授权者的名称,一般填写成和 ID 一致的字符串 String
– – – URI 预设用户组,请参见 ACL 概述 文档中预设用户组部分,例如http://cam.qcloud.com/groups/global/AllUsershttp://cam.qcloud.com/groups/global/AuthenticatedUsers String

回调函数说明

function(err, data) { ... }
参数名 参数描述 类型
err 请求发生错误时返回的对象,包括网络错误和业务错误,如果请求成功则为空,更多详情请参见 错误码 文档 Object
– statusCode 请求返回的 HTTP 状态码,例如200、403、404等 Number
– headers 请求返回的头部信息 Object
data 请求成功时返回的对象,如果请求发生错误,则为空 Object
– statusCode 请求返回的 HTTP 状态码,例如200、403、404等 Number
– headers 请求返回的头部信息 Object

查询存储桶 ACL

功能说明

GET Bucket acl 接口用来查询存储桶的访问控制列表(ACL)。该 API 的请求者需要对存储桶有写入 ACL 权限。

使用示例

cos.getBucketAcl({    Bucket: 'examplebucket-1250000000', /* 必须 */    Region: 'COS_REGION'     /* 必须 */}, function(err, data) {    console.log(err || data);});

返回示例

{    "GrantFullControl": "",    "GrantWrite": "",    "GrantRead": "",    "GrantReadAcp": "id=\"qcs::cam::uin/100000000011:uin/100000000011\"",    "GrantWriteAcp": "id=\"qcs::cam::uin/100000000011:uin/100000000011\"",    "ACL": "private",    "Owner": {        "ID": "qcs::cam::uin/100000000001:uin/100000000001",        "DisplayName": "qcs::cam::uin/100000000001:uin/100000000001"    },    "Grants": [{        "Grantee": {            "ID": "qcs::cam::uin/100000000011:uin/100000000011",            "DisplayName": "qcs::cam::uin/100000000011:uin/100000000011"        },        "Permission": "READ"    }],    "statusCode": 200,    "headers": {}}

参数说明

参数名 参数描述 类型 是否必填
Bucket 存储桶的名称,命名格式为 BucketName-APPID,此处填写的存储桶名称必须为此格式 String
Region 存储桶所在地域,枚举值请参见 地域和访问域名 String

回调函数说明

function(err, data) { ... }
参数名 参数描述 类型
err 请求发生错误时返回的对象,包括网络错误和业务错误,如果请求成功则为空,更多详情请参见 错误码 文档 Object
– statusCode 请求返回的 HTTP 状态码,例如200、403、404等 Number
– headers 请求返回的头部信息 Object
data 请求成功时返回的对象,如果请求发生错误则为空 Object
– statusCode 请求返回的 HTTP 状态码,例如200、403、404等 Number
– headers 请求返回的头部信息 Object
– ACL 定义存储桶的访问控制列表(ACL)属性。枚举值请参见 ACL 概述 文档中存储桶的预设 ACL 部分,例如 private,public-read 等,默认为 private String
– GrantRead 具有读取存储桶权限的被授权者 ID 信息 String
– GrantWrite 具有写入存储桶权限的被授权者 ID 信息 String
– GrantReadAcp 具有读取存储桶的访问控制列表(ACL)和存储桶策略(Policy)权限的被授权者 ID 信息 String
– GrantWriteAcp 具有写入存储桶的访问控制列表(ACL)和存储桶策略(Policy)权限的被授权者 ID 信息 String
– GrantFullControl 具有存储桶所有权限的被授权者 ID 信息 String
– Owner 存储桶持有者的信息 Object
– – DisplayName 存储桶持有者的名称 String
– – ID 存储桶持有者的完整 ID,格式为qcs::cam::uin/:uin/如果是主账号, 和 是同一个值 String
– Grants 被授权者信息与权限信息列表 ObjectArray
– – Permission 指明授予被授权者的权限信息,枚举值:READ、WRITE、READ_ACP、WRITE_ACP、FULL_CONTROL String
– – Grantee 被授权者的信息 Object
– – – DisplayName 被授权者的名称 String
– – – ID 被授权者的完整 ID:如果是主账号,格式为qcs::cam::uin/:uin/qcs::cam::anyone:anyone (指代所有用户)如果是子账号,格式为qcs::cam::uin/:uin/ String
– – – URI 预设用户组,请参见 ACL 概述 文档中预设用户组部分,例如http://cam.qcloud.com/groups/global/AllUsershttp://cam.qcloud.com/groups/global/AuthenticatedUsers String

对象 ACL

设置对象 ACL

功能说明

PUT Object acl 接口用来设置特定存储桶中某个对象的访问控制列表(ACL)。注意每个主账号(即同一个 APPID),存储桶的 ACL、Policy 和 CAM 关联的策略数量总和最多为1000条,对象访问控制列表(ACL)规则数量不限制。如果您不需要进行对象访问控制列表(ACL)控制,请不要设置,默认继承存储桶权限。

使用示例

cos.putObjectAcl({    Bucket: 'examplebucket-1250000000', /* 必须 */    Region: 'COS_REGION',    /* 必须 */    Key: 'exampleobject',              /* 必须 */    ACL: 'public-read',        /* 非必须 */}, function(err, data) {    console.log(err || data);});

为某个用户赋予对象的所有权限:

cos.putObjectAcl({    Bucket: 'examplebucket-1250000000', /* 必须 */    Region: 'COS_REGION',    /* 必须 */    Key: 'exampleobject',              /* 必须 */    GrantFullControl: 'id="100000000001"' // 100000000001是主账号 uin}, function(err, data) {    console.log(err || data);});

通过 AccessControlPolicy 赋予对象写权限:

cos.putObjectAcl({    Bucket: 'examplebucket-1250000000', /* 必须 */    Region: 'COS_REGION',    /* 必须 */    Key: 'exampleobject',              /* 必须 */    AccessControlPolicy: {        "Owner": { // AccessControlPolicy 里必须有 owner            "ID": 'qcs::cam::uin/100000000001:uin/100000000001' // 100000000001 是主账号 uin        },        "Grants": [{            "Grantee": {                "ID": "qcs::cam::uin/100000000011:uin/100000000011", // 100000000011 是主账号下的子账号 uin            },            "Permission": "WRITE"        }]    }}, function(err, data) {    console.log(err || data);});

参数说明

参数名 参数描述 类型 是否必填
Bucket 存储桶的名称,命名格式为 BucketName-APPID,此处填写的存储桶名称必须为此格式 String
Region 存储桶所在地域,枚举值请参见 地域和访问域名 String
Key 对象键(Object 的名称),对象在存储桶中的唯一标识,详情请参见 对象概述 String
ACL 定义对象的访问控制列表(ACL)属性,枚举值请参见 ACL 概述 文档中对象的预设 ACL 部分,例如 default,private,public-read 等注意:如果您不需要进行对象 ACL 控制,请设置为 default 或者此项不进行设置,默认继承存储桶权限 String
GrantRead 赋予被授权者读取对象的权限。格式:id=”[OwnerUin]”,可使用半角逗号(,)分隔多组被授权者:当需要给子账号授权时,id="qcs::cam::uin/:uin/"当需要给主账号授权时,id="qcs::cam::uin/:uin/"例如'id="qcs::cam::uin/100000000001:uin/100000000001", id="qcs::cam::uin/100000000001:uin/100000000011"' String
GrantFullControl 赋予被授权者操作对象的所有权限,格式:id=”[OwnerUin]”,可使用半角逗号(,)分隔多组被授权者:当需要给子账号授权时,id="qcs::cam::uin/:uin/"当需要给主账号授权时,id="qcs::cam::uin/:uin/"例如'id="qcs::cam::uin/100000000001:uin/100000000001", id="qcs::cam::uin/100000000001:uin/100000000011"' String
AccessControlPolicy 设置对象的访问控制列表(ACL)属性信息 Object
– Owner 对象持有者的信息 Object
– – ID 对象持有者 ID,格式:qcs::cam::uin/:uin/如果是主账号, 和 是同一个值 String
– – DisplayName 对象持有者的名称 String
– Grants 被授权者信息与权限信息列表 ObjectArray
– – Permission 指明授予被授权者的权限信息,枚举值:READ、WRITE、READ_ACP、WRITE_ACP、FULL_CONTROL String
– – Grantee 被授权者的信息 Object
– – – DisplayName 被授权者的名称 String
– – – ID 被授权者的 ID,格式:qcs::cam::uin/:uin/如果是主账号, 和 是同一个值 String

回调函数说明

function(err, data) { ... }
参数名 参数描述 类型
err 请求发生错误时返回的对象,包括网络错误和业务错误,如果请求成功则为空,更多详情请参见 错误码 文档 Object
– statusCode 请求返回的 HTTP 状态码,例如200、403、404等 Number
– headers 请求返回的头部信息 Object
data 请求成功时返回的对象,如果请求发生错误,则为空 Object
– statusCode 请求返回的 HTTP 状态码,例如200,204,403,404等 Number
– headers 请求返回的头部信息 Object

查询对象 ACL

功能说明

GET Object acl 接口用来查询某个存储桶下的某个对象的访问权限。只有存储桶的持有者才有权限操作。

使用示例

cos.getObjectAcl({    Bucket: 'examplebucket-1250000000', /* 必须 */    Region: 'COS_REGION',    /* 必须 */    Key: 'exampleobject',              /* 必须 */}, function(err, data) {    console.log(err || data);});

参数说明

参数名 参数描述 类型 是否必填
Bucket 存储桶的名称,命名格式为 BucketName-APPID,此处填写的存储桶名称必须为此格式 String
Region 存储桶所在地域,枚举值请参见 地域和访问域名 String
Key 对象键(Object 的名称),对象在存储桶中的唯一标识,详情请参见 对象概述 String

回调函数说明

function(err, data) { ... }
参数名 参数描述 类型
err 请求发生错误时返回的对象,包括网络错误和业务错误,如果请求成功则为空,更多详情请参见 错误码 文档 Object
– statusCode 请求返回的 HTTP 状态码,例如200、403、404等 Number
– headers 请求返回的头部信息 Object
data 请求成功时返回的对象,如果请求发生错误,则为空 Object
– statusCode 请求返回的 HTTP 状态码,例如200、403、404等 Number
– headers 请求返回的头部信息 Object
– ACL 对象的访问控制列表(ACL)属性,枚举值请参见 ACL 概述 文档中对象的预设 ACL 部分,例如 default,private,public-read 等 String
– Owner 标识资源的所有者 Object
– – ID 对象持有者 ID,格式为:qcs::cam::uin/:uin/如果是主账号 ID, 和 是同一个值 String
– – DisplayName 对象持有者的名称 String
– Grants 被授权者信息与权限信息列表 ObjectArray
– – Permission 指明授予被授权者的权限信息,枚举值:READ、READ_ACP、WRITE_ACP、FULL_CONTROL String
– – Grantee 被授权者的信息 Object
– – – DisplayName 用户的名称 String
– – – ID 用户的 ID,格式为:qcs::cam::uin/:uin/如果是主账号 ID, 和 是同一个值 String



对象存储官网1折活动,限时活动,即将结束,速速收藏
同尘科技腾讯云授权服务中心。
购买腾讯云产品享受折上折,更有现金返利。同意关联立享优惠

转转请注明出处:https://www.yunxiaoer.com/145892.html

(0)
上一篇 2023年12月9日
下一篇 2023年12月9日
详情页2

相关推荐

  • Flink有什么办法可以只启用一个吗?-云小二-阿里云

    我们现在从源端MySQL库接入数据,现在发现是接同一个库下面的多张表会启用多个MySQL bin log的监听,Flink有什么办法可以只启用一个吗? 以下为热心网友提供的参考意见 当在Flink中从MySQL库接入多张表的数据时,如果启用了MySQL bin log的监听,通常每个表都会单独启用一个bin log监听器。这是因为每个表都有自己的数据源和流,…

    阿里云 2023年12月20日
  • 腾讯云对象存储设置历史数据审核任务

    简介 本文介绍如何通过控制台使用对象存储(Cloud Object Storage,COS)内容审核的历史数据审核功能。您可以通过创建历史数据审核任务,对您的图片、视频、音频、文本、文档进行一次性的批量审核。 操作步骤 创建审核任务 1. 登录 对象存储控制台。2. 在左侧导航栏中,选择存储桶列表,进入存储桶管理页面。3. 找到需要操作的存储桶,单击该存储桶…

    2023年12月9日
  • 腾讯云对象存储图片审核回调内容

    功能描述 若您配置了审核回调地址,在图片审核结束后,后台会将审核结果以 json 形式回调至您的回调地址。您可以通过回调内容,进行后续的文件处理操作。回调内容分为简洁回调(Simple)和详细回调(Detail)。  回调内容说明 简洁回调(Simple) 回调通知为HTTP的POST方法,含有 X-Ci-Content-Version: Simple…

    2023年12月9日
  • 阿里云RDS数据库重置密码-云淘科技

    在使用RDS过程中,如果忘记数据库账号密码,可以通过控制台重新设置密码。 操作步骤 访问RDS实例列表,在上方选择地域,然后单击目标实例ID。 在左侧导航栏单击账号管理。 在待重置密码的账号的操作列,单击重置密码。 在弹出的对话框中输入新密码并确认,然后单击确定。 密码要求如下: 长度为8~32个字符。 由大写字母、小写字母、数字、特殊字符中的任意三种组成。…

    2023年12月9日
  • 信息流广告,信息流部分建议宽度830px,只针对默认列表样式,顺序随机
  • 腾讯云对象存储用于前端直传 COS 的临时密钥安全指引

    简介 在移动应用和 Web 应用中,您可以通过 iOS/Android/JavaScript SDK 在前端直接向对象存储(Cloud Object Storage,COS)发起请求,此时数据的上传和下载可以不经过您的后端服务器,既节约了您后端服务器的带宽和负载,还可以充分利用 COS 的带宽和全球加速等能力,提升您的应用体验。在实际应用中,您需要使用临时密…

    腾讯云 2023年12月9日

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信
本站为广大会员提供阿里云、腾讯云、华为云、百度云等一线大厂的购买,续费优惠,保证底价,买贵退差。