Here’s a focused feature guide for — covering setup, templating, rendering, and streaming. 1. Core Concept Thymeleaf alone doesn’t generate PDFs. Common approach: Thymeleaf → HTML → Flying Saucer / OpenPDF → PDF
public PdfController(PdfService pdfService) this.pdfService = pdfService;
private final SpringTemplateEngine templateEngine; taming thymeleaf pdf download
return ResponseEntity.ok() .header(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=invoice_" + id + ".pdf") .contentType(MediaType.APPLICATION_PDF) .body(pdfBytes);
String html = templateEngine.process("invoice", context); Here’s a focused feature guide for — covering
public PdfService(SpringTemplateEngine templateEngine) this.templateEngine = templateEngine;
<img src="file:/absolute/path/logo.png" /> (register in ITextRenderer): Common approach: Thymeleaf → HTML → Flying Saucer
public byte[] generateInvoicePdf(InvoiceDto invoice) Context context = new Context(); context.setVariable("invoice", invoice);
try ITextRenderer renderer = new ITextRenderer(); renderer.setDocumentFromString(html); renderer.layout(); return renderer.createPDF(null); // byte array output catch (Exception e) throw new RuntimeException("PDF generation failed", e);
@GetMapping("/invoice/id/pdf") public ResponseEntity<byte[]> downloadInvoice(@PathVariable Long id) InvoiceDto invoice = invoiceService.findById(id); // your logic byte[] pdfBytes = pdfService.generateInvoicePdf(invoice);
private final PdfService pdfService;