访问控制

最后更新时间:2020-08-10 11:08:37

    简介

    本文档提供关于存储桶、对象的访问控制列表(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 查询对象的访问控制列表

    SDK API 参考

    SDK 所有接口的具体参数与方法说明,请参考 SDK API 参考

    存储桶 ACL

    设置存储桶 ACL

    功能说明

    设置指定存储桶的访问权限控制列表(ACL)。

    示例代码

    String bucket = "examplebucket-1250000000"; //格式:BucketName-APPID
    PutBucketACLRequest putBucketACLRequest = new PutBucketACLRequest(bucket);
    
    // 设置 bucket 访问权限
    putBucketACLRequest.setXCOSACL("public-read");
    
    // 赋予被授权者读的权限
    ACLAccount readACLS = new ACLAccount();
    readACLS.addAccount("100000000001", "100000000001");
    putBucketACLRequest.setXCOSGrantRead(readACLS);
    
    // 赋予被授权者写的权限
    ACLAccount writeACLS = new ACLAccount();
    writeACLS.addAccount("100000000001", "100000000001");
    putBucketACLRequest.setXCOSGrantWrite(writeACLS);
    
    // 赋予被授权者读写的权限
    ACLAccount writeandReadACLS = new ACLAccount();
    writeandReadACLS.addAccount("100000000001", "100000000001");
    putBucketACLRequest.setXCOSReadWrite(writeandReadACLS);
    
    cosXmlService.putBucketACLAsync(putBucketACLRequest,
            new CosXmlResultListener() {
        @Override
        public void onSuccess(CosXmlRequest request, CosXmlResult result) {
            PutBucketACLResult putBucketACLResult = (PutBucketACLResult) result;
        }
    
        @Override
        public void onFail(CosXmlRequest cosXmlRequest,
                           CosXmlClientException clientException,
                           CosXmlServiceException serviceException) {
            if (clientException != null) {
                clientException.printStackTrace();
            } else {
                serviceException.printStackTrace();
            }
        }
    });

    说明:

    更多完整示例,请前往GitHub 查看。

    查询存储桶 ACL

    功能说明

    查询指定存储桶的访问权限控制列表(ACL)。

    示例代码

    String bucket = "examplebucket-1250000000"; //格式:BucketName-APPID
    GetBucketACLRequest getBucketACLRequest = new GetBucketACLRequest(bucket);
    cosXmlService.getBucketACLAsync(getBucketACLRequest,
            new CosXmlResultListener() {
        @Override
        public void onSuccess(CosXmlRequest request, CosXmlResult result) {
            GetBucketACLResult getBucketACLResult = (GetBucketACLResult) result;
        }
    
        @Override
        public void onFail(CosXmlRequest cosXmlRequest,
                           CosXmlClientException clientException,
                           CosXmlServiceException serviceException) {
            if (clientException != null) {
                clientException.printStackTrace();
            } else {
                serviceException.printStackTrace();
            }
        }
    });

    说明:

    更多完整示例,请前往GitHub查看。

    对象 ACL

    设置对象 ACL

    功能说明

    设置存储桶中某个对象的访问控制列表(ACL)。

    示例代码

    String bucket = "examplebucket-1250000000"; //格式:BucketName-APPID
    String cosPath = "exampleobject"; //对象在存储桶中的位置标识符,即对象键。
    PutObjectACLRequest putObjectACLRequest = new PutObjectACLRequest(bucket,
            cosPath);
    
    // 设置 对象 访问权限
    putObjectACLRequest.setXCOSACL("public-read");
    
    // 赋予被授权者读的权限
    ACLAccount readACLS = new ACLAccount();
    readACLS.addAccount("100000000001", "100000000001");
    putObjectACLRequest.setXCOSGrantRead(readACLS);
    
    // 赋予被授权者读写的权限
    ACLAccount writeandReadACLS = new ACLAccount();
    writeandReadACLS.addAccount("100000000001", "100000000001");
    putObjectACLRequest.setXCOSReadWrite(writeandReadACLS);
    
    cosXmlService.putObjectACLAsync(putObjectACLRequest,
            new CosXmlResultListener() {
        @Override
        public void onSuccess(CosXmlRequest request, CosXmlResult result) {
            PutObjectACLResult putObjectACLResult = (PutObjectACLResult) result;
        }
    
        @Override
        public void onFail(CosXmlRequest cosXmlRequest,
                           CosXmlClientException clientException,
                           CosXmlServiceException serviceException) {
            if (clientException != null) {
                clientException.printStackTrace();
            } else {
                serviceException.printStackTrace();
            }
        }
    });

    说明:

    更多完整示例,请前往 GitHub查看。

    查询对象 ACL

    功能说明

    查询对象的访问控制列表。

    示例代码

    String bucket = "examplebucket-1250000000"; //格式:BucketName-APPID
    String cosPath = "exampleobject"; //对象在存储桶中的位置标识符,即对象键。
    GetObjectACLRequest getBucketACLRequest = new GetObjectACLRequest(bucket,
            cosPath);
    cosXmlService.getObjectACLAsync(getBucketACLRequest,
            new CosXmlResultListener() {
        @Override
        public void onSuccess(CosXmlRequest request, CosXmlResult result) {
            GetObjectACLResult getObjectACLResult = (GetObjectACLResult) result;
        }
    
        @Override
        public void onFail(CosXmlRequest cosXmlRequest,
                           CosXmlClientException clientException,
                           CosXmlServiceException serviceException) {
            if (clientException != null) {
                clientException.printStackTrace();
            } else {
                serviceException.printStackTrace();
            }
        }
    });

    说明:

    更多完整示例,请前往 GitHub 查看。

    Was this page helpful?

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

    • 完全没帮助
    • 文档较差
    • 文档一般
    • 文档不错
    • 文档很好
    反馈
    帮助