Tạo file PDF trong Java, sử dụng Flying Saucer và Thymeleaf


ảnh minh họa -  Học lập trình Java
Chắc hẳn các bạn đã quá quen thuộc với các file định dạng PDF. nà CV, các văn bản đặc tả spec, các công văn, thưa, các vé điện tử .v.v.v Điều đó đặt ra đề nghị các vận dụng web phải có khả năng xuất file PDF với format nào đó hợp với từng yêu cầu của hệ thống chức năng. Bài viết bữa nay của mình sẽ hướng dẫn các bạn dùng Java để thực hiện điều đó!

 


Trong bài này, các bạn sẽ thấy, quá trình xuất file PDF của mình gồm 2 bước chính như sau

Sử Thymeleaf để đưa dữ liệu vào mẫu và từ đó nhận được document dạng XHTML với các data đã được bind. Mình tỉ dụ hình trên, $$name được gán với giá trị Thomas

Save document XHTML đó dưới dạng PDF sử dụng Flying Saucer.

Lưu ý rằngm 2 bước trên là hoàn toàn đoọc lập. Chúng ta có thể dễ dàng dùng các template engine khác (thí dụ như Apache FreeMarker) hay thậm chí là HTML thuần. Tuy nhiên, bài viết này sử dụng Thymeleaf là vì chưng Thymeleaf là 1 template engine rất phổ thông được biệt là khi làm việc với Spring
 
1. Bước 1: Cài đặt project
Để bắt đầu, chúng ta cần 3 dependenciescompile group: 'org.thymeleaf', name: 'thymeleaf', version: '3.0.6.RELEASE' compile group: 'org.xhtmlrenderer', name: 'flying-saucer-core', version: '9.1.6' compile group: 'org.xhtmlrenderer', name: 'flying-saucer-pdf-itext5', version: '9.1.6' 

2. Bước 2: Thymeleaf Template

Đầu tiên, để đơn giản cho các bạn dễ hình dung, mình sẽ sử dụng 1 thí dụ đơn giản trước, Ở đây Thymeleaf Template mình tạo đơn giản như sau
Hi! My name is [[$name]]!

 

và đển render template này với ThymeLeaf, bạn có thể sử dụng đoạn code sauClassLoaderTemplateResolver templateResolver = new ClassLoaderTemplateResolver(); templateResolver.setSuffix(".html"); templateResolver.setTemplateMode("HTML"); TemplateEngine templateEngine = new TemplateEngine(); templateEngine.setTemplateResolver(templateResolver); Context context = new Context(); // Gán giá trị "Thomas" cho biến name để lát nữa bind dữ liệu context.setVariable("name", "Thomas"); // Trả về chuỗi là html string sau khi thực hành bind dữ liệu String html = templateEngine.process("template", context); 

Và như thế, bạn đã có 1 chuỗi là chuỗi htlml sau khi bind dữ liệu (name = Thomas).

Việc tiếp theo là sử dụng chuỗi này cho việc chuyển hóa sang PDF thôi.

Chú ý rằng, tỉ dụ này của mình chỉ là 1 tỉ dụ hết sức đơn giản. ThymeLeaf thực tế còn mạnh hơn rất nhiều với việc cung cấp các cấu trúc lệnh for, if và gọi lệnh Java trong template. Bạn có thể tìm được rất nhiều các vi dụ và chỉ dẫn trên internet  Hãy thử nhé.
 
3. Bước 3: PDF Generation

Đến với bước 3, rất đơn giản. Về cơ bản, chúng ta chỉ cần có chuỗi HTML và dùng nó trong đọan code dưới đâyOutputStream outputStream = new FileOutputStream("message.pdf"); ITextRenderer renderer = new ITextRenderer(); renderer.setDocumentFromString(html); renderer.layout(); renderer.createPDF(outputStream); outputStream.close(); 

Và thành tựu là đây
    4. Nâng cấp

thí dụ bên trên thực tiễn là 1 tỉ dụ quá đơn giản và nó k đc ứng dụng trong thực tiễn. Trong thực tiễn, file PDF có bố cục và nội dụng phức tạp hơn rất nhiều. Như vậy, chúng ta đổi thay chiến thuật
 
Và như thế, để gen ra được 1 file PDF, chúng ta sẽ phải đi qua vài bước như sau
Đầu tiên, chúng ta có 1 Thymeleaf HTML template. Mẫu này được bind data bằng việc dùng Thymeleaf rendering engine
Flying Saucer yêu cầu XHTML. nên chúng ta cần chuyển đổi HTML sang XHTML. Để làm đc điều đó, chúng ta dùng JTidy.
XHTML file refer tới các
rút cuộc, chuyển đổi từ XHTML sang PDF bằng Flying Saucer

Chúng ta có thể làm design file PDF của mình bằng cách design thymeleaf template. Như là

Chỉ định file css
... 

Hoặc thậm chí viết css ngay trong đó.logo width: 275px; h1 font-size: 18px; margin-bottom: 40px; margin-top: 40px; p font-size: 12px;  

Hoặc là nhét ảnh vào *TEST BARCODE*  

Nói chung, về cơ bản, việc chúng ta cần phải làm là design XHTML cho ổn, sau đó FlyingSaucer sẽ chuyển đổi nó sang PDF cho bạn

0 Response to "Tạo file PDF trong Java, sử dụng Flying Saucer và Thymeleaf"

Đăng nhận xét

powered by Blogger | WordPress by Newwpthemes | Converted by ocsenden