tencent cloud

对象存储

动态与公告
产品动态
产品公告
产品简介
产品概述
功能概览
应用场景
产品优势
基本概念
地域和访问域名
规格与限制
产品计费
计费概述
计费方式
计费项
免费额度
计费示例
查看和下载账单
欠费说明
常见问题
快速入门
控制台快速入门
COSBrowser 快速入门
用户指南
创建请求
存储桶
对象
数据管理
批量处理
全球加速
监控与告警
运维中心
数据处理
内容审核
智能工具箱
数据工作流
应用集成
工具指南
工具概览
环境安装与配置
COSBrowser 工具
COSCLI 工具
COSCMD 工具
COS Migration 工具
FTP Server 工具
Hadoop 工具
COSDistCp 工具
HDFS TO COS 工具
GooseFS-Lite 工具
在线辅助工具
自助诊断工具
实践教程
概览
访问控制与权限管理
性能优化
使用 AWS S3 SDK 访问 COS
数据容灾备份
域名管理实践
图片处理实践
COS 音视频播放器实践
工作流实践
数据直传
内容审核实践
数据安全
数据校验
大数据实践
COS 成本优化解决方案
在第三方应用中使用 COS
迁移指南
本地数据迁移至 COS
第三方云存储数据迁移至 COS
以 URL 作为源地址的数据迁移至 COS
COS 之间数据迁移
Hadoop 文件系统与 COS 之间的数据迁移
数据湖存储
云原生数据湖
元数据加速
数据加速器 GooseFS
数据处理
数据处理概述
图片处理
媒体处理
内容审核
文件处理
文档处理
故障处理
获取 RequestId 操作指引
通过外网上传文件至 COS 缓慢
访问 COS 时返回403错误码
资源访问异常
POST Object 常见异常
API 文档
简介
公共请求头部
公共响应头部
错误码
请求签名
操作列表
Service 接口
Bucket 接口
Object 接口
批量处理接口
数据处理接口
任务与工作流
内容审核接口
云查毒接口
SDK 文档
SDK 概览
准备工作
Android SDK
C SDK
C++ SDK
.NET(C#) SDK
Flutter SDK
Go SDK
iOS SDK
Java SDK
JavaScript SDK
Node.js SDK
PHP SDK
Python SDK
React Native SDK
小程序 SDK
错误码
鸿蒙(Harmony) SDK
终端 SDK 质量优化
安全与合规
数据容灾
数据安全
访问管理
常见问题
热门问题
一般性问题
计费计量问题
域名合规问题
存储桶配置问题
域名和 CDN 问题
文件操作问题
日志监控问题
权限管理问题
数据处理问题
数据安全问题
预签名 URL 问题
SDK 类问题
工具类问题
API 类问题
服务协议
Service Level Agreement
隐私政策
数据处理和安全协议
联系我们
词汇表

ACL

PDF
聚焦模式
字号
最后更新时间: 2025-09-11 16:15:52

基本概念

访问控制列表(ACL)使用 XML 语言描述,是与资源关联的一个指定被授权者和授予权限的列表,每个存储桶和对象都有与之关联的 ACL,支持向匿名用户或其他腾讯云的主账号授予基本的读写权限。
注意:
使用与资源关联的 ACL 管理有一些限制:
资源的拥有者始终对资源具备 FULL_CONTROL 权限,无法撤销或修改。
匿名用户无法成为资源拥有者,此时对象资源的拥有者属于存储桶的创建者(腾讯云主账号)。
仅可对腾讯云访问管理(Cloud Access Management,CAM)主账号或预设用户组授予权限,无法授予自定义用户组权限,不推荐授予子用户权限。
不支持对权限附加条件。
不支持显示拒绝的权限。
一个资源最多可以拥有100条 ACL 策略。

适用场景

注意:
开放匿名用户访问(公有读)属于高危操作,有流量盗刷的风险;必须使用公有读时,可 设置防盗链 进行安全防护。
当您仅需要为存储桶和对象设置一些简单的访问权限或开放匿名访问,可以选择 ACL。但在更多的情况下,推荐您优先使用存储桶策略或用户策略,灵活程度更高。ACL 的适用场景包括:
仅设置简单的访问权限。
在控制台快速设置访问权限。
需要将某个对象、目录或存储桶开放给所有互联网匿名用户访问,ACL 操作更为便捷。

ACL 的元素

身份 Grantee

支持的被授权身份可以是某个 CAM 主账号,或者是某个预设的 CAM 用户组。
注意:
当您授予了其他腾讯云主账号访问权限时,这个被授权的主账号可以授权其名下的子用户、用户组或角色的访问权限。
对象存储(Cloud Object Storage,COS)完全不建议您对匿名用户或 CAM 用户组授予 WRITE、WRITE_ACP 或 FULL_CONTROL 权限。一旦授权后,用户组可以对您的资源进行上传、下载、删除等行为,这将会给您带来数据丢失、扣费等风险。
在存储桶或对象的 ACL 中支持授予的身份包括:
跨账号:请使用主账号的 ID,通过账号中心账号信息 获得账号 ID,例如100000000001。
预设用户组:请使用 URI 标签标记预设的用户组,支持的用户组包括:
匿名用户组 -http://cam.qcloud.com/groups/global/AllUsers 该组代表了任何人都可以无需授权而访问资源,无论请求已签名或者未签名。
认证用户组 -http://cam.qcloud.com/groups/global/AuthenticatedUsers 该组代表所有经过腾讯云 CAM 账户认证的用户都可以访问资源。

操作 Permission

腾讯云 COS 在资源 ACL 上支持的操作实际上是一系列的操作集合,对于存储桶和对象 ACL 来说分别代表不同的含义。

存储桶的操作

下表列出了支持在存储桶 ACL 中设置的操作列表:
操作集
描述
许可的行为
READ
列出对象
HeadBucket、GetBucketObjectVersions、ListMultipartUploads
WRITE
上传、覆盖和删除对象
PutObject、PutObjectCopy、PostObject、InitiateMultipartUpload、UploadPart、UploadPartCopy、CompleteMultipartUpload、 DeleteObject
READ_ACP
读取存储桶的 ACL
GetBucketACL
WRITE_ACP
写入存储桶的 ACL
PutBucketACL
FULL_CONTROL
以上四种权限的集合
以上所有行为的集合
注意:
请谨慎授予存储桶 WRITE、WRITE_ACP 或 FULL_CONTROL 权限。授予存储桶 WRITE 权限将允许被授权者覆盖或删除已有的任何对象。

对象的操作

下表列出了支持在对象 ACL 中设置的操作列表:
操作集
描述
许可的行为
READ
读取对象
GetObject、GetObjectVersion、HeadObject
READ_ACP
读取对象的 ACL
GetObjectACL、GetObjectVersionACL
WRITE_ACP
写入对象的 ACL
PutObjectACL、PutObjectVersionACL
FULL_CONTROL
以上三种权限的集合
以上所有行为的集合
说明:
对象不支持授予 WRITE 操作集。

预设的 ACL

COS 支持一系列预设的 ACL 进行授权,方便简单权限的描述。使用预设 ACL 描述时,需要在 PUT Bucket/Object 或 PUT Bucket/Object acl 中携带 x-cos-acl 头部并描述所需权限,如果同时在请求正文中携带了 XML 的描述内容,我们将优先选择头部中的描述并忽略请求正文中的 XML 描述。

存储桶的预设 ACL

预设名称
描述
private
创建者(主账号)具备 FULL_CONTROL 权限,其他人没有权限(默认)
public-read
创建者具备 FULL_CONTROL 权限,匿名用户组具备 READ 权限
public-read-write
创建者和匿名用户组都具备 FULL_CONTROL 权限,通常不建议授予此权限
authenticated-read
创建者具备 FULL_CONTROL 权限,认证用户组具备 READ 权限

对象的预设 ACL

预设名称
描述
default
空描述,此时根据各级目录的显式设置及存储桶的设置来确定是否允许请求(默认)
private
创建者(主账号)具备 FULL_CONTROL 权限,其他人没有权限
public-read
创建者具备 FULL_CONTROL 权限,匿名用户组具备 READ 权限
authenticated-read
创建者具备 FULL_CONTROL 权限,认证用户组具备 READ 权限
bucket-owner-read
创建者具备 FULL_CONTROL 权限,存储桶拥有者具备 READ 权限
bucket-owner-full-control
创建者和存储桶拥有者都具备 FULL_CONTROL 权限
说明:
对象不支持授予 public-read-write 权限。

示例

存储桶的 ACL

在创建存储桶时,COS 将创建一个默认的 ACL 以赋予资源拥有者对资源的完全控制权限(FULL_CONTROL),示例如下:
<AccessControlPolicy>
<Owner>
<ID>Owner-Cononical-CAM-User-Id</ID>
</Owner>
<AccessControlList>
<Grant>
<Grantee>
<ID>Owner-Cononical-CAM-User-Id</ID>
</Grantee>
<Permission>FULL_CONTROL</Permission>
</Grant>
</AccessControlList>
</AccessControlPolicy>

对象的 ACL

在创建对象时,COS 默认不会创建 ACL,此时对象的拥有者为存储桶拥有者。对象继承存储桶的权限,与存储桶的访问权限一致。由于对象没有默认的 ACL,其将遵循存储桶策略(Bucket Policy)中对访问者和其行为的定义,来判断请求是否被许可。详情请参见 访问策略语言概述 文档。
如果您需要对对象授予其他访问权限,您可以在此基础上添加更多的 ACL 来描述对象的访问权限。例如授予匿名用户只读单个对象的权限,示例如下:
<AccessControlPolicy>
<Owner>
<ID>Owner-Cononical-CAM-User-Id</ID>
</Owner>
<AccessControlList>
<Grant>
<Grantee>
<ID>Owner-Cononical-CAM-User-Id</ID>
</Grantee>
<Permission>FULL_CONTROL</Permission>
</Grant>
<Grant>
<Grantee>
<URI>http://cam.qcloud.com/groups/global/AllUsers</URI>
</Grantee>
<Permission>READ</Permission>
</Grant>
</AccessControlList>
</AccessControlPolicy>

使用方法

使用对象存储控制台

设置存储桶访问权限

您可以通过对象存储控制台来设置或修改存储桶的访问权限。对象存储 COS 支持设置两种权限类型:
公共权限:私有读写、公有读私有写和公有读写。关于公共权限的说明,请参见存储桶概述中的 权限类别
用户权限:主账号默认拥有存储桶所有权限(即完全控制)。另外 COS 支持添加子账号有数据读取、数据写入、权限读取(即授予用户读取“存储桶访问权限”的权限)、权限写入(即授予用户写入“存储桶访问权限”的权限),甚至完全控制的最高权限。
说明:
当存储桶为私有读写或对指定账号授予用户权限,请求对象时需携带签名用于身份验证,关于签名说明,请参见 请求签名
当存储桶为公有读私有写或公有读写时,请求对象时无需携带签名,匿名用户可直接通过链接访问对象,您的数据会存在泄露风险,请谨慎设置。
单个授权
2. 在左侧导航栏中,单击存储桶列表
3. 找到您需要设置或修改访问权限的存储桶,单击其存储桶名称。
4. 在存储桶配置页面,单击权限管理 > 存储桶访问权限,对存储桶的公共权限和用户权限(例如添加子账号,子账号 ID 可在 访问管理 控制台查看)进行设置。
注意:
若您必须使用公有读私有写或公有读写权限且未配置默认告警,则推荐开启告警策略。若已配置,则无需配置且不提示。
5. 单击保存,即可完成存储桶访问权限设置。
批量授权
2. 在左侧导航栏中,单击存储桶列表
3. 单击列表上方的授权管理
4. 在弹窗中选择希望授权的存储桶。然后对存储桶的公共权限和用户权限(例如添加子账号,子账号 ID 可在 访问管理 控制台查看)进行设置。
注意:
授权管理将同时修改公共权限和用户权限。
若您只需修改用户权限,请务必先检查您之前存储桶的公共权限和当前配置是否一致,否则会覆盖之前的权限。
5. 配置完成后,单击确定,即可完成多个存储桶的访问权限设置。

设置对象的访问权限

对象存储(Cloud Object Storage,COS)提供基于对象维度的访问权限设置,且该权限优先级高于存储桶的访问权限。
说明:
对象的访问权限只在用户通过默认域名访问时有效。通过 CDN 加速域名和自定义域名访问时,以存储桶访问权限为准。
访问策略规则存在数量限制,详情请参见 规格与限制
操作步骤
2. 在左侧导航栏中,单击存储桶列表,进入存储桶列表页面。
3. 找到对象所在的存储桶,单击其存储桶名称,进入存储桶管理页面。
4. 在左侧导航栏中,选择文件列表,进入文件列表页面。
5. 找到需要设置权限的对象,并单击右侧的详情,进入文件详情页。(若是文件夹,可单击右侧的设置权限)。
6. 在“对象访问权限”栏中,根据实际需求,设置访问权限。
COS 支持为对象设置两种权限类型:
公共权限:包括继承权限、私有读写、公有读私有写。关于公共权限的说明,请参见对象概述中的 权限类别
用户权限:主账号默认拥有对象所有权限(即完全控制)。
7. 单击保存,即可设置对象的访问权限。
若您需要对多个对象进行批量设置或修改访问权限,可勾选多个对象,并单击上方的更多操作 > 修改访问权限即可设置。

使用 REST API/SDK

您可以通过以下 API 管理存储桶/对象 ACL:
管理存储桶 ACL
管理对象 ACL
您可以直接调用 SDK 管理存储桶/对象 ACL,详情请参见下列各语言 SDK 文档:

使用工具

您可以使用工具管理存储桶/对象 ACL,例如 COSBrowserCOSCMDCOSCLI,更多工具介绍请参见 工具概览


帮助和支持

本页内容是否解决了您的问题?

填写满意度调查问卷,共创更好文档体验。

文档反馈