【问题标题】:java - downloading a input stream using servletsjava - 使用 servlet 下载输入流
【发布时间】:2017-04-07 08:15:45
【问题描述】:

我正在使用以下代码从 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();

【问题讨论】:

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


    【解决方案1】:

    除了文件读取部分,一切都正确。

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

    【讨论】:

    • 您好,谢谢!但这没有任何区别,我也没有得到任何异常
    • 您好,请问您还有其他见解吗?我仍然坚持这个:(
    猜你喜欢
    • 1970-01-01
    • 2012-11-17
    • 2012-01-02
    • 1970-01-01
    • 2014-07-30
    • 1970-01-01
    • 1970-01-01
    • 2017-08-31
    • 1970-01-01
    相关资源
    最近更新 更多