我需要返回一个HttpServletResponse来使用iText下载包含PDF的ZIP文件。这是我的代码:
String fileName = "Acreditaciones.zip";
ByteArrayOutputStream baos = new ByteArrayOutputStream();
ZipOutputStream zos = new ZipOutputStream(baos);
for(int i = 0; i < numAcre; i++){
zos.putNextEntry(new ZipEntry("Acreditaciones" + String.valueOf(i+1) + ".pdf"));
Document document = new Document();
PdfWriter.getInstance(document, baos);
//Abrimos el documento para insertarle contenido
document.open();
//TODO: Coger la URL de los parametros de la BD y cifrar el id del perceptor o la columna que lo identifique
//Creamos imagen con codigo QR
BarcodeQRCode barcodeQRCode2 = new BarcodeQRCode(URL + UtilsSeguridad.cifrar("80004244D"), 1000, 1000, null);
Image codeQrImage2 = barcodeQRCode2.getImage();
codeQrImage2.setAlignment(Image.RIGHT);
codeQrImage2.scaleAbsolute(70, 70);
document.add(codeQrImage2);
document.close();
zos.closeEntry();
}
zos.finish();
zos.close();
response.setHeader("Content-Disposition", "attachment; filename=\""+ fileName + "\";");
// Indicamos que es un PDF
response.setContentType("application/zip");
// El tamaño del contenido es igual al del ByteArrayOutputStream
response.setContentLength(baos.size());
// Inyectamos el ByteArrayOutputStream al ServletOutputStream
ServletOutputStream os = response.getOutputStream();
baos.writeTo(os);
os.flush();
os.close();
FacesContext.getCurrentInstance().responseComplete();
当我下载ZIP文件时,这会带来所有PDF损坏且没有大小...我不知道我做错了什么,但似乎文档没有被实例化。
答案 0 :(得分:4)
替换以下行:
PdfWriter.getInstance(document, baos);
这两行:
PdfWriter writer = PdfWriter.getInstance(document, zos);
writer.setCloseStream(false);
请勿忘记告诉writer
实例不要关闭基础流,否则关闭document
实例也会关闭ZipOutputStream
,并且您赢了“{1}}实例。能够添加新条目。