0

我正在使用以下代码从 s3 存储桶中的对象获取内容。我可以将数据复制到本地文件中,但该文件需要“下载”并且必须显示在浏览器的下载列表中。我对此进行了一些搜索,然后cam知道这与 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();
4

1 回答 1

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块中将帮助您了解问题的确切原因。

于 2017-04-07T08:48:56.007 回答