java - 使用servlet下载输入流

时间:2017-04-07 08:15:46

标签: java servlets amazon-s3 aws-java-sdk

我使用以下代码从s3存储桶中的对象获取内容。我可以在本地将数据复制到文件中,但文件需要“下载”,并且必须显示在浏览器的下载列表中。 我搜索了一下这个并且知道这与response.setHeader( "Content-Disposition", "attachment;filename=\"" + filename + "\"" );有关 我试图添加它,但不知何故无法让它工作。我的理解是源必须是服务器上的文件,该文件被转换为流。但我以输入流的形式获得s3内容。如何在浏览器中将其下载为文件? 以下是我到目前为止尝试的代码

AmazonS3 s3 = new AmazonS3Client(new ProfileCredentialsProvider());    
S3Object fetchFile = s3.getObject(new GetObjectRequest(bucketname, fileloc));
        final BufferedInputStream i = new BufferedInputStream(fetchFile.getObjectContent());
        response.setContentType("application/json");
        response.setHeader( "Content-Disposition", "attachment;filename=\"" + filename + "\"" );            
        ServletOutputStream sos = response.getOutputStream();
        int bytesread = i.read();
        while(bytesread!=-1)
        {
            sos.write(bytesread);
            bytesread = i.read();
        }
        if(i!= null)i.close();
        if(sos!= null)sos.close();

1 个答案:

答案 0 :(得分:0)

除文件阅读部分外,一切正常。

//Set the size of buffer to stream the data.
  byte []buffer=new byte[1024*8];

而不是

  int byte=i.read();

现在阅读文件。

  while( ( length = yourInputStream.read(buffer))!=-1)
    {       yourOutputStream.write(buffer); 
                }
    System.out.println("File is downloaded.");

此外,将整个代码放在 try / catch 块中将有助于您了解问题的确切原因。