全部产品
阿里云办公

管理存储空间

更新时间:2018-08-15 23:26:09

存储空间(Bucket)是存储对象(Object)的容器。对象都隶属于存储空间。

创建存储空间

以下代码用于创建存储空间:

  1. // Endpoint以杭州为例,其它Region请按实际情况填写。
  2. String endpoint = "http://oss-cn-hangzhou.aliyuncs.com";
  3. // 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://ram.console.aliyun.com 创建RAM账号。
  4. String accessKeyId = "<yourAccessKeyId>";
  5. String accessKeySecret = "<yourAccessKeySecret>";
  6. // 创建OSSClient实例。
  7. OSSClient ossClient = new OSSClient(endpoint, accessKeyId, accessKeySecret);
  8. // 创建存储空间。
  9. String bucketName = "<yourBucketName>";
  10. // 新建存储空间默认为标准存储类型,私有权限。
  11. ossClient.createBucket(bucketName);
  12. // 关闭OSSClient。
  13. ossClient.shutdown();

存储空间的命名规范,请参见基本概念中的命名规范。

您可以在创建存储空间时指定存储空间的权限存储类型。如果需要创建低频或归档类型的存储空间,请使用Java SDK 2.6.0及以上版本。示例代码如下:

  1. CreateBucketRequest createBucketRequest = new CreateBucketRequest(bucketName);
  2. // 设置存储空间的权限为公共读,默认是私有。
  3. createBucketRequest.setCannedACL(CannedAccessControlList.PublicRead);
  4. // 设置存储空间的存储类型为低频访问类型,默认是标准类型。
  5. createBucketRequest.setStorageClass(StorageClass.IA);
  6. ossClient.createBucket(createBucketRequest);

列举存储空间

存储空间按照字母顺序排列。您可以列举所有的存储空间,或符合指定条件的存储空间。如果有低频类型或归档类型的存储空间,请使用Java SDK 2.6.0及以上版本。

列举所有的存储空间

以下代码用于列举所有的存储空间:

  1. // Endpoint以杭州为例,其它Region请按实际情况填写。
  2. String endpoint = "http://oss-cn-hangzhou.aliyuncs.com";
  3. // 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://ram.console.aliyun.com 创建RAM账号。
  4. String accessKeyId = "<yourAccessKeyId>";
  5. String accessKeySecret = "<yourAccessKeySecret>";
  6. // 创建OSSClient实例。
  7. OSSClient ossClient = new OSSClient(endpoint, accessKeyId, accessKeySecret);
  8. // 列举存储空间。
  9. List<Bucket> buckets = ossClient.listBuckets();
  10. for (Bucket bucket : buckets) {
  11. System.out.println(" - " + bucket.getName());
  12. }
  13. // 关闭OSSClient。
  14. ossClient.shutdown();

列举指定前缀的存储空间

以下代码用于列举包含指定前缀(prefix)的存储空间:

  1. ListBucketsRequest listBucketsRequest = new ListBucketsRequest();
  2. // 列举指定前缀的存储空间。
  3. listBucketsRequest.setPrefix("<yourBucketPrefix>");
  4. BucketList bucketList = ossClient.listBuckets(listBucketsRequest);
  5. for (Bucket bucket : bucketList.getBucketList()) {
  6. System.out.println(" - " + bucket.getName());
  7. }

列举指定marker之后的存储空间

参数marker代表存储空间名称。以下代码用于列举指定marker之后的存储空间:

  1. ListBucketsRequest listBucketsRequest = new ListBucketsRequest();
  2. // 列举指定marker之后的存储空间。
  3. listBucketsRequest.setMarker("<yourBucketMarker>");
  4. BucketList bucketList = ossClient.listBuckets(listBucketsRequest);
  5. for (Bucket bucket : bucketList.getBucketList()) {
  6. System.out.println(" - " + bucket.getName());
  7. }

列举指定个数的存储空间

以下代码用于列举指定个数(maxKeys)的存储空间:

  1. ListBucketsRequest listBucketsRequest = new ListBucketsRequest();
  2. // 限定此次列举存储空间的个数为500。默认值为100,最大值为1000。
  3. listBucketsRequest.setMaxKeys(500);
  4. BucketList bucketList = ossClient.listBuckets(listBucketsRequest);
  5. for (Bucket bucket : bucketList.getBucketList()) {
  6. System.out.println(" - " + bucket.getName());
  7. }

判断存储空间是否存在

以下代码用于判断指定的存储空间是否存在:

  1. // Endpoint以杭州为例,其它Region请按实际情况填写。
  2. String endpoint = "http://oss-cn-hangzhou.aliyuncs.com";
  3. // 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://ram.console.aliyun.com 创建RAM账号。
  4. String accessKeyId = "<yourAccessKeyId>";
  5. String accessKeySecret = "<yourAccessKeySecret>";
  6. // 创建OSSClient实例。
  7. OSSClient ossClient = new OSSClient(endpoint, accessKeyId, accessKeySecret);
  8. boolean exists = ossClient.doesBucketExist("<yourBucketName>");
  9. // 关闭OSSClient。
  10. ossClient.shutdown();

设置存储空间的访问权限

存储空间的访问权限(ACL)有以下三类:

访问权限 描述 访问权限值
私有 存储空间的拥有者和授权用户有该存储空间内的文件的读写权限,其他用户没有权限操作该存储空间内的文件。 CannedAccessControlList.Private
公共读 存储空间的拥有者和授权用户有该存储空间内的文件的读写权限,其他用户只有该存储空间内的文件的读权限。请谨慎使用该权限。 CannedAccessControlList.PublicRead
公共读写 所有用户都有该存储空间内的文件的读写权限。请谨慎使用该权限。 CannedAccessControlList.PublicReadWrite

以下代码用于设置存储空间的访问权限:

  1. // Endpoint以杭州为例,其它Region请按实际情况填写。
  2. String endpoint = "http://oss-cn-hangzhou.aliyuncs.com";
  3. // 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://ram.console.aliyun.com 创建RAM账号。
  4. String accessKeyId = "<yourAccessKeyId>";
  5. String accessKeySecret = "<yourAccessKeySecret>";
  6. // 创建OSSClient实例。
  7. OSSClient ossClient = new OSSClient(endpoint, accessKeyId, accessKeySecret);
  8. // 设置存储空间的访问权限为私有。
  9. ossClient.setBucketAcl("<yourBucketName>", CannedAccessControlList.Private);
  10. // 关闭OSSClient。
  11. ossClient.shutdown();

获取存储空间的访问权限

以下代码用于获取存储空间的访问权限:

  1. // Endpoint以杭州为例,其它Region请按实际情况填写。
  2. String endpoint = "http://oss-cn-hangzhou.aliyuncs.com";
  3. // 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://ram.console.aliyun.com 创建RAM账号。
  4. String accessKeyId = "<yourAccessKeyId>";
  5. String accessKeySecret = "<yourAccessKeySecret>";
  6. // 创建OSSClient实例。
  7. OSSClient ossClient = new OSSClient(endpoint, accessKeyId, accessKeySecret);
  8. // 获取存储空间的访问权限。
  9. AccessControlList acl = ossClient.getBucketAcl("<yourBucketName>");
  10. System.out.println(acl.toString());
  11. // 关闭OSSClient。
  12. ossClient.shutdown();

获取存储空间的地域

以下代码用于获取存储空间的地域(称为Region或Location):

  1. // Endpoint以杭州为例,其它Region请按实际情况填写。
  2. String endpoint = "http://oss-cn-hangzhou.aliyuncs.com";
  3. // 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://ram.console.aliyun.com 创建RAM账号。
  4. String accessKeyId = "<yourAccessKeyId>";
  5. String accessKeySecret = "<yourAccessKeySecret>";
  6. // 创建OSSClient实例。
  7. OSSClient ossClient = new OSSClient(endpoint, accessKeyId, accessKeySecret);
  8. String location = ossClient.getBucketLocation("<yourBucketName>");
  9. System.out.println(location);
  10. // 关闭OSSClient。
  11. ossClient.shutdown();

关于地域的详细信息请参见基本概念中的地域。

获取存储空间的信息

以下代码用于获取存储空间的信息(Info):

  1. // Endpoint以杭州为例,其它Region请按实际情况填写。
  2. String endpoint = "http://oss-cn-hangzhou.aliyuncs.com";
  3. // 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://ram.console.aliyun.com 创建RAM账号。
  4. String accessKeyId = "<yourAccessKeyId>";
  5. String accessKeySecret = "<yourAccessKeySecret>";
  6. // 创建OSSClient实例。
  7. OSSClient ossClient = new OSSClient(endpoint, accessKeyId, accessKeySecret);
  8. // 存储空间的信息包括地域(Region或Location)、创建日期(CreationDate)、拥有者(Owner)、权限(Grants)等。
  9. BucketInfo info = ossClient.getBucketInfo("<yourBucketName>");
  10. // 获取地域。
  11. info.getBucket().getLocation();
  12. // 获取创建日期。
  13. info.getBucket().getCreationDate();
  14. // 获取拥有者信息。
  15. info.getBucket().getOwner();
  16. // 获取权限信息。
  17. info.getGrants();
  18. // 关闭OSSClient。
  19. ossClient.shutdown();

删除存储空间

删除存储空间之前,必须先删除存储空间下的所有文件、LiveChannel和分片上传产生的碎片。

说明:要删除分片上传产生的碎片,首先使用Bucket.ListMultipartUploads列举出所有碎片,然后使用Bucket.AbortMultipartUpload删除这些碎片。

以下代码用于删除存储空间:

  1. // Endpoint以杭州为例,其它Region请按实际情况填写。
  2. String endpoint = "http://oss-cn-hangzhou.aliyuncs.com";
  3. // 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://ram.console.aliyun.com 创建RAM账号。
  4. String accessKeyId = "<yourAccessKeyId>";
  5. String accessKeySecret = "<yourAccessKeySecret>";
  6. // 创建OSSClient实例。
  7. OSSClient ossClient = new OSSClient(endpoint, accessKeyId, accessKeySecret);
  8. // 删除存储空间。
  9. ossClient.deleteBucket("<yourBucketName>");
  10. // 关闭OSSClient。
  11. ossClient.shutdown();
本文导读目录