概述
对象存储(Cloud Object Storage,COS)在数据写入数据中心内的磁盘之前,支持在对象级别上应用数据加密的保护策略,并在访问数据时自动解密。加密和解密这一操作过程都是在服务端完成,这种服务端加密功能可以有效保护静态数据。
注意:
访问加密对象与访问未加密的对象在体验上并无差别,但前提是用户已拥有对象的访问权限。
服务端加密仅加密对象数据而不加密对象元数据。
在列出存储桶中对象时,列表会返回所有对象的列表,无论对象是否加密。
适用场景
私密数据存储场景:对于私密数据的存储,服务端加密可以对存储的数据进行加密,保证用户的隐私,用户访问时会自动解密。
私密数据传输场景:对于私密数据的传输,COS 提供用 HTTPS 部署 SSL 证书实现加密的功能,在传输链路层上建立加密层,确保数据在传输过程中不会被窃取及篡改。
加密方式
COS 支持多种服务端加密方式:SSE-COS、SSE-KMS、SSE-C。用户可以自行选择合适的加密方式对存放到 COS 中的数据进行加密。
SSE-COS 加密
SSE-COS 加密即 COS 托管密钥的服务端加密。由腾讯云 COS 托管主密钥和管理数据。用户通过 COS 直接对数据进行管理和加密。SSE-COS 采用了多因素强加密,确保使用唯一的密钥加密每个对象,并且会通过定期轮换的主密钥来对密钥本身进行加密。
SSE-COS 模式支持 AES256 和 SM4 两种加密算法,默认使用 AES256 算法,上传对象时可以通过服务端加密头部 x-cos-server-side-encryption 指定加密算法。
注意:
对于使用预签名 URL 上传的对象,则无法使用 SSE-COS 加密。只能使用 COS 控制台或 HTTP 请求头部指定服务端加密。
SSE-KMS 加密
SSE-KMS 加密即使用 KMS 托管密钥的服务端加密。KMS 是腾讯云推出的一款安全管理类服务,使用经过第三方认证的硬件安全模块 HSM(Hardware Security Module)来生成和保护密钥。它能够帮助用户轻松创建和管理密钥,满足用户多应用多业务的密钥管理需求以及满足监管和合规要求。
SSE-KMS 模式支持 AES256 和 SM4 两种加密算法,默认使用 AES256 算法,上传对象时可以通过服务端加密头部 x-cos-server-side-encryption-cos-kms-algorithm 指定加密算法。
首次使用 SSE-KMS 加密,需要 开通 KMS 服务,开通 KMS 服务后,系统会自动为您创建一个默认主密钥(CMK)。您也可以通过 KMS 控制台 自主创建密钥,定义密钥策略及使用方法,KMS 支持用户自主选择密钥材料来源为 KMS 或外部,更多信息请参见 创建密钥 和 外部密钥导入。
注意:
SSE-KMS 仅加密对象数据,不会加密任何对象元数据。
目前 SSE-KMS 仅支持北京、上海、广州、中国香港地域。
使用 SSE-KMS 加密,会产生额外费用,由 KMS 收取,详情请参见 KMS 计费概述。
使用 SSE-KMS 加密的对象必须使用有效签名访问,不可被匿名用户访问。
注意事项
1. 登录访问管理控制台,进入 角色 列表页面。
2. 单击新建角色,选择角色载体为腾讯云产品服务。
3. 选择支持角色的服务为对象存储,单击下一步。
4. 配置角色策略,搜索并勾选 QcloudKMSAccessForCOSRole,单击下一步。
5. 标记角色的标签键和标签值,单击下一步。
6. 输入指定角色名称:COS_QCSRole。
说明:
访问管理 CAM 角色列表中,存量的角色名称“COS_QcsRole”仍可继续使用,生效状态不受影响。
7. 单击完成即可创建完毕。
SSE-C 加密
SSE-C 加密即用户自定义密钥的服务端加密。加密密钥由用户自己提供,用户在上传对象时,COS 将使用用户提供的加密密钥对用户的数据进行加密。SSE-KMS 模式支持 AES256 和 SM4 两种加密算法,默认使用 AES256算法,上传对象时可以通过服务端加密头部 x-cos-server-side-encryption-cos-kms-algorithm 指定加密算法。
注意:
COS 不存储用户提供的加密密钥,而是存储加密密钥添加了随机数据的 HMAC 值,该值用于验证用户访问对象的请求。COS 无法使用随机数据的 HMAC 值来推导出加密密钥的值或解密加密对象的内容。因此,如果用户丢失了加密密钥,则无法再次获取到该对象。
使用方法
使用对象存储控制台
注意:
SSE-C 加密不支持控制台操作,仅能通过 API 使用。
SSE-COS、SSE-KMS 加密的 SM4 算法当前不支持控制台、SDK调用,仅能通过 API 使用。
使用 REST API
对于 SSE-COS、SSE-KMS 加密,支持以下 API 接口:
说明:
如果使用非 POST 请求上传对象,可通过提供
x-cos-server-side-encryption-*
头部来应用服务端加密;使用 POST 请求,则需在表单字段中提供 x-cos-server-side-encryption-*
字段,详情请参见 POST Object。对于 SSE-C 加密,支持以下 API 接口:
说明:
如果使用非 POST 请求上传对象,可通过提供
x-cos-server-side-encryption-*
头部来应用服务端加密;使用 POST 请求,则需在表单字段中提供 x-cos-server-side-encryption-*
字段,详情请参见 POST Object。当通过 GET Object 和 HEAD Object 接口请求 SSE-C 加密的对象时,需要提供
x-cos-server-side-encryption-*
头部来解密指定对象,详情请参见 公共请求头部 - SSE-C。使用 SDK
C
Go
iOS
Java
PHP
小程序