18

我有一个 s3 结构如下:

s3bucketname -> List of first level keys -> List of second level keys -> List of third level keys -> Actual file.

我需要做的是,给定 s3bucket 的名称和第一级键的条目,我需要位于第一级键下的所有第二级键的名称。所以本质上,如果我们把它看成一个文件夹,我会得到root folders3bucketname的名称和其中一个子文件夹的名称subfolder1,我想列出所有位于其中的文件夹subfolder1。只是名称,而不是完整的路径。

有人可以指出如何使用亚马逊的 java sdk 在 java 中做到这一点吗?

谢谢

4

2 回答 2

49

我做了以下似乎工作正常的代码,您必须传递 aprefix并确保前缀以/结尾,并指定要获取子目录列表的分隔符。以下应该有效:

public List<String> listKeysInDirectory(String bucketName, String prefix) {
    String delimiter = "/";
    if (!prefix.endsWith(delimiter)) {
        prefix += delimiter;
    }

    ListObjectsRequest listObjectsRequest = new ListObjectsRequest()
            .withBucketName(bucketName).withPrefix(prefix)
            .withDelimiter(delimiter);
    ObjectListing objects = _client.listObjects(listObjectsRequest);
    return objects.getCommonPrefixes();
}
于 2013-02-01T19:54:07.453 回答
9

查尔斯版超级简洁!谢谢@charles-menguy

我写了一个扩展来通过分页支持巨大的列表。

    public List<String> getSubPathsInS3Prefix(String bucketName, String prefix) {
        if (!prefix.endsWith(FILE_DELIMITER)) {
            prefix += FILE_DELIMITER;
        }
        List<String> paths = new ArrayList<String>();
        ListObjectsRequest listObjectsRequest = new ListObjectsRequest()
                .withBucketName(bucketName).withPrefix(prefix)
                .withMaxKeys(1000).withDelimiter(FILE_DELIMITER);
        ObjectListing currentListing = s3Client.listObjects(listObjectsRequest);
        paths.addAll(currentListing.getCommonPrefixes());

        while (currentListing == null || currentListing.isTruncated()) {
            currentListing = s3Client.listNextBatchOfObjects(currentListing);
            paths.addAll(currentListing.getCommonPrefixes());
        }
        return paths;
    }

http://www.lazywiz.com/uncategorized/s3-missing-api-list-sub-paths-in-the-s3-bucket/

于 2016-03-14T20:18:34.263 回答