存储空间(Bucket)是存储对象(Object)的容器。对象都隶属于存储空间。本文介绍如何设置和获取存储空间读写权限(ACL)。
注意事项
- 本文以华东1(杭州)外网Endpoint为例。如果您希望通过与OSS同地域的其他阿里云产品访问OSS,请使用内网Endpoint。关于OSS支持的Region与Endpoint的对应关系,请参见访问域名和数据中心。
- 本文以OSS域名新建OSSClient为例。如果您希望通过自定义域名、STS等方式新建OSSClient,请参见.NET初始化。
- 要设置存储空间读写权限,您必须有
oss:PutBucketAcl
权限;要获取存储空间读写权限,您必须有oss:GetBucketAcl
权限。具体操作,请参见为RAM用户授权自定义的权限策略。
设置存储空间读写权限
存储空间的读写权限(ACL)有以下三类:
取值 | 描述 | 方法 |
---|---|---|
私有 | 存储空间的拥有者和授权用户有该存储空间内的文件的读写权限,其他用户没有权限操作该存储空间内的文件。 | CannedAccessControlList.Private |
公共读 | 存储空间的拥有者和授权用户有该存储空间内的文件的读写权限,其他用户只有该存储空间内的文件的读权限。请谨慎使用该权限。 | CannedAccessControlList.PublicRead |
公共读写 | 所有用户都有该存储空间内的文件的读写权限。请谨慎使用该权限。 | CannedAccessControlList.PublicReadWrite |
以下代码用于设置存储空间的读写权限:
using Aliyun.OSS;
// yourEndpoint填写Bucket所在地域对应的Endpoint。以华东1(杭州)为例,Endpoint填写为https://oss-cn-hangzhou.aliyuncs.com。
var endpoint = "yourEndpoint";
// 阿里云账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM用户进行API访问或日常运维,请登录RAM控制台创建RAM用户。
var accessKeyId = "yourAccessKeyId";
var accessKeySecret = "yourAccessKeySecret";
// yourBucketName填写Bucket名称。
var bucketName = "yourBucketName";
// 初始化OSSClient实例。
var client = new OssClient(endpoint, accessKeyId, accessKeySecret);
public void SetBucketAcl(string bucketName)
{
try
{
// 设置存储空间的读写权限为公共读。
client.SetBucketAcl(bucketName, CannedAccessControlList.PublicRead);
Console.WriteLine("Set bucket ACL succeeded");
}
catch (Exception ex)
{
Console.WriteLine("Set bucket ACL failed. {0}", ex.Message);
}
}
获取存储空间访问权限
以下代码用于获取存储空间的读写权限:
using Aliyun.OSS;
// yourEndpoint填写Bucket所在地域对应的Endpoint。以华东1(杭州)为例,Endpoint填写为https://oss-cn-hangzhou.aliyuncs.com。
var endpoint = "yourEndpoint";
// 阿里云账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM用户进行API访问或日常运维,请登录RAM控制台创建RAM用户。
var accessKeyId = "yourAccessKeyId";
var accessKeySecret = "yourAccessKeySecret";
// 初始化OSSClient实例。
var client = new OssClient(endpoint, accessKeyId, accessKeySecret);
// 获取存储空间的访问权限。
public void GetBucketAcl(string bucketName)
{
try
{
// yourBucketName填写存储空间名称。
string bucketName = "yourBucketName";
var acl = client.GetBucketAcl(bucketName);
Console.WriteLine("Get bucket ACL success",acl.ACL.ToString());
}
catch (Exception ex)
{
Console.WriteLine("Get bucket ACL failed. {0}", ex.Message);
}
}
相关文档
- 关于设置存储空间读写权限的完整示例代码,请参见GitHub示例。
- 关于获取存储空间读写权限的完整示例代码,请参见GitHub示例
- 关于设置存储空间读写权限的API接口说明,请参见PutBucketAcl。
- 关于获取存储空间读写权限的API接口说明,请参见GetBucketAcl。