Spring 启动 Angular2,return JSON 中的 PDF

Spring boot Angular2, return PDF in JSON

我有一个 Spring 引导 REST API,它必须 return 一个 PDF。我已将 PDF 转换为字节数组,然后在 return 发送给客户端之前用 base64 对其进行编码。

这是我的界面:

@ApiOperation(value = "Update an existing form", notes = "Update an existing form ", response = Void.class, tags={  })
    @ApiResponses(value = {
            @ApiResponse(code = 200, message = "form response", response = Void.class),
            @ApiResponse(code = 200, message = "unexpected error", response = Void.class) })
    @RequestMapping(value = "/forms/{formId}/submissions/{submissionId}/pdf",
            method = RequestMethod.GET)
    ResponseEntity<Resource> pdf(
            @ApiParam(value = "Id of the form that needs to be updated", required = true) @PathVariable("formId") Long formId,
            @ApiParam(value = "Id of the submission that needs to be updated", required = true) @PathVariable("submissionId") Long submissionId,
            @ApiParam(value = "token to be passed as a header", required = true) @RequestHeader(value = "token", required = true) String token
    );

以及实现的方法:

@Override
    public ResponseEntity<Resource> pdf(@ApiParam(value = "Id of the form that needs to be updated", required = true) @PathVariable("formId") Long formId, @ApiParam(value = "Id of the submission that needs to be updated", required = true) @PathVariable("submissionId") Long submissionId, @ApiParam(value = "token to be passed as a header", required = true) @RequestHeader(value = "token", required = true) String token) {
        String name = JWTutils.getEmailInToken(token);

        if(name == null) {
            return new ResponseEntity<>(HttpStatus.FORBIDDEN);
        }

        User user = userRepository.findByEmail(name);

        if(user == null){
            return  new ResponseEntity<>(HttpStatus.FORBIDDEN);
        }

        Form form = formRepository.findById(formId);

        if(form == null){
            return new ResponseEntity<>(HttpStatus.NOT_FOUND);
        }

        Submission submission = submissionRepository.findOne(submissionId);

        if(submission == null){
            return new ResponseEntity<>(HttpStatus.NOT_FOUND);
        }

        //Saving the document
        final PDPage singlePage = new PDPage();
        final PDFont courierBoldFont = PDType1Font.COURIER_BOLD;
        final int fontSize = 12;
        ByteArrayOutputStream out = new ByteArrayOutputStream();
        try (final PDDocument document = new PDDocument())
        {
            document.addPage(singlePage);
            final PDPageContentStream contentStream = new PDPageContentStream(document, singlePage);
            contentStream.beginText();
            contentStream.setFont(courierBoldFont, fontSize);
            contentStream.newLineAtOffset(150, 750);
            contentStream.showText("Hello PDFBox");
            contentStream.showText("Hello PDFBox");
            contentStream.showText("Hello PDFBox");
            contentStream.showText("Hello PDFBox");
            contentStream.showText("Hello PDFBox");
            contentStream.showText("Hello PDFBox");
            contentStream.showText("Hello PDFBox");
            contentStream.showText("Hello PDFBox");
            contentStream.showText("Hello PDFBox");
            contentStream.endText();
            contentStream.close();  // Stream must be closed before saving document.
            //document.save("pdfs/" + UUID.randomUUID().toString() + ".pdf");
            document.save(out);
        }
        catch (IOException ioEx)
        {
            ioEx.printStackTrace();
        }

        byte[] b64 = Base64.getEncoder().encode(out.toByteArray());
        ByteArrayResource resource = new ByteArrayResource(b64);

        return ResponseEntity.ok()
                .contentLength(b64.length)
                .contentType(MediaType.parseMediaType("application/octet-stream"))
                .body(resource);
    }

这是 Angular2 中的代码:

generatePdf(){
    this.submissionService.generatePdf(this.form.id, this.submission.id).then(data => {
        console.log(JSON.stringify(data));
        let file = new Blob([atob(data._body)]);
        FileSaver.saveAs(file, 'helloworld.pdf')
    }).catch(error => {
        console.log(error);
    });
}

我在有效负载中收到的 PDF 如下所示:PasteBin

当我打开下载的 PDF 时,它只有一页空白,而真正的 pdf 包含文本。知道发生了什么吗?我觉得是关于编码的。


解决方案

我不得不更改服务中的 GET 请求。我已将此添加到我的请求中 responseType: ResponseContentType.Blob;

return this.http.get(this.formsUrl + "/" + formId + "/submissions/" + submissionId + "/pdf", {headers: headers, responseType: ResponseContentType.Blob})
        .toPromise()
        .then(res => res)
        .catch(this.handleError);

解决方案

我不得不更改服务中的 GET 请求。我已将此添加到我的请求中 responseType: ResponseContentType.Blob;

return this.http.get(this.formsUrl + "/" + formId + "/submissions/" + submissionId + "/pdf", {headers: headers, responseType: ResponseContentType.Blob})
        .toPromise()
        .then(res => res)
        .catch(this.handleError);