如何从s3 url获取(前n个字节)文件

时间:2014-07-02 17:56:20

标签: object amazon-s3 get

这是一个基本问题,不是很先进,但我有点卡住了。

我正在尝试获取s3上托管的文件的前n个字节。我理解这个问题的基本构建块。我知道如何获取字节。以下是AmazonS3的一个示例

GET /example-object HTTP/1.1
Host: example-bucket.s3.amazonaws.com
x-amz-date: Fri, 28 Jan 2011 21:32:02 GMT
Range: bytes=0-9
Authorization: AWS AKIAIOSFODNN7EXAMPLE:Yxg83MZaEgh3OZ3l0rLo5RTX11o=
Sample Response with Specified Range of the Object Bytes  

现在我有一个s3网址,就像这样:

http://s3.amazonaws.com/bucket-name/foo/1/2/3/4/file.jpg

如何将此翻译成文档中指定的请求?我知道这是补救措施,但是我被困住了,这感觉有点不透明,尽管那可能只是我。

请帮我解构s3 url到GET请求示例的组件。感谢帮助!

更新:如果我要使用GetObjectRequest api,我将使用什么来构建器中的存储桶和密钥?

UPDATE2:换句话说就像

一样简单
// modelled after http://s3.amazonaws.com/foo/
private String s3UrlToBucket(String s3Url)
{
    Pattern pattern = Pattern.compile("^https?://[^/]+/([^/]+)/.*$");
    Matcher matcher = pattern.matcher(s3Url);
    if(matcher.find())
    {
        return matcher.group(1);
    }
    return null;
}

// modelled after http://s3.amazonaws.com/foo/1/2/3/4.jpg
private String s3UrlToKey(String s3Url)
{
    Pattern pattern = Pattern.compile("^https?://[^/]+/[^/]+/(.*)$");
    Matcher matcher = pattern.matcher(s3Url);
    if(matcher.find())
    {
        return matcher.group(1);
    }
    return null;
}

更新3:你能否告诉我钥匙是什么意思?

2 个答案:

答案 0 :(得分:6)

如果您使用AWS SDK for Java,则只需在GetObjectRequest上设置范围即可。这是一个代码示例:

AmazonS3Client s3Client = new AmazonS3Client();
GetObjectRequest request = new GetObjectRequest("bucket-name", "foo/1/2/3/4/file.jpg");
request.withRange(0, numberOfBytesToGet);
S3Object s3Object = s3Client.getObject(request);
//s3Object.getObjectContent() has a stream to your object.

答案 1 :(得分:0)

如果您在Ruby(我们已经使用了很长时间了)方面很努力,那么正确的语法是:

s3_resource.bucket(bucket).object(key).get(range: "bytes=0-3").body.read