gpt4 book ai didi

java - Grails 从 REST Web 服务端点下载 pdf 文件

转载 作者:行者123 更新时间:2023-11-30 07:04:42 25 4
gpt4 key购买 nike

我正在尝试编写一个调用 REST 端点的功能,它给我返回一个休息响应 content-type: application/pdf ,看起来像这样:

%PDF-1.4 %���� 4304 0 obj

4330 0 obj <</C 1636/Filter/FlateDecode/I 1658/Length 1188/S 1431/T 1552>>stream h�bb�����������؀���cP�a\h�b�q���K��f���X���%�s<�o�� ��u.{��b�'�6��&����:�mV�ꛒ��妴�قU�"��I�\T�.��l��

当我尝试获取该主体的类时,它告诉我它是一个字符串。

这就是我的 Controller 的样子...

def download(){

try{

def documentContent = //rest response//

if(documentContents){
String body = documentContents.body
byte[] data = body.getBytes("UTF-8")

response.setContentType("application/pdf")
response.setContentLength(data.length)
response.setCharacterEncoding("UTF-8")
response.setHeader("Content-disposition","attachment;filename=test.pdf")

response.outputStream << data
response.outputStream.flush()
response.outputStream.close()
return
}
}

catch(Exception e){

println("abc")
}

render status: 204

从我的 Controller 中,我获得了一个包含页面的 pdf 文件,但它全是空白。

最佳答案

我现在没有看到重大差异,但这对我有用......

def generatePdf(){
ByteArrayOutputStream docStream = /*call that generates pdf data*/
response.setHeader(HttpHeaders.CONTENT_DISPOSITION, 'inline; filename=print.pdf')
response.setContentType('applicaton/pdf')
response.contentLength = docStream.size()
response.outputStream << docStream.toByteArray()
}

要明确说明其工作原理:请注意缺少 response.setCharacterEncoding()。仅当响应是某种纯文本时,才适合使用 response.setCharacterEncoding() 。在您的情况下,响应是 PDF、二进制文件,而不是文本。

关于java - Grails 从 REST Web 服务端点下载 pdf 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40347620/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com