S3下载pdf - REST API

时间:2018-04-26 13:00:23

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

我正在尝试使用Spring Boot Rest API提供存储在S3上的一个PDF。

以下是我的代码:

        byte[] targetArray = null;

        InputStream is = null;

        S3Object object = s3Client
                    .getObject(new GetObjectRequest("S3_BUCKET_NAME", "prefixUrl"));

        InputStream objectData = object.getObjectContent();

    BufferedReader reader = new BufferedReader(new InputStreamReader(objectData));

    char[] charArray = new char[8 * 1024];
    StringBuilder builder = new StringBuilder();
    int numCharsRead;
    while ((numCharsRead = reader.read(charArray, 0, charArray.length)) != -1) {

        builder.append(charArray, 0, numCharsRead);
    }
    reader.close();

    objectData.close();
    object.close();
    targetArray = builder.toString().getBytes();

    is = new ByteArrayInputStream(targetArray);


    return ResponseEntity.ok().contentLength(targetArray.length).contentType(MediaType.APPLICATION_PDF)
                    .cacheControl(CacheControl.noCache()).header("Content-Disposition", "attachment; filename=" + "testing.pdf")
                    .body(new InputStreamResource(is));

当我使用邮递员点击我的API时,我可以下载PDF文件,但问题是它完全是空白的。可能是什么问题?

S3流数据并不保留缓冲区,数据是二进制(PDF),因此如何使用Rest API将这些数据服务。

如何解决这个问题?

1 个答案:

答案 0 :(得分:5)

以下简单代码应该适合您,不知道为什么要尝试将字符转换为字节,反之亦然? 尝试这个,它工作正常。 PostMan / Browser。

@GET
@RequestMapping("/document")
@Consumes(MediaType.APPLICATION_OCTET_STREAM)
@Produces("application/pdf")
public ResponseEntity<InputStreamResource> getDocument() throws IOException {

    final AmazonS3 s3 = AmazonS3ClientBuilder.defaultClient();

    S3Object object = s3.getObject("BUCKET-NAME", "DOCUMENT-URL");
    S3ObjectInputStream s3is = object.getObjectContent();


    return ResponseEntity.ok().contentType(org.springframework.http.MediaType.APPLICATION_PDF).cacheControl(CacheControl.noCache())
            .header("Content-Disposition", "attachment; filename=" + "testing.pdf")
            .body(new InputStreamResource(s3is));

}