使用Thymeleaf-没有js的html模板导出为pdf

html模板

html 复制代码
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">

<head>
    <title>PDF Template</title>
</head>
<body>
<h1>User Information</h1>
<p>Name: <span th:text="${user.name}"></span></p>
[[${user.getName()}]]
[[${user.name}]]111
<p>Email: <span th:text="${user.email}"></span></p>
</body>
</html>

依赖

java 复制代码
        <!-- thymeleaf for html to pdf -->
        <dependency>
            <groupId>org.thymeleaf</groupId>
            <artifactId>thymeleaf</artifactId>
            <version>${org.thymeleaf.version}</version>
            <scope>compile</scope>
        </dependency>

PDFGenerator

java 复制代码
import org.springframework.stereotype.Component;
import org.thymeleaf.TemplateEngine;
import org.thymeleaf.context.Context;
import org.thymeleaf.templateresolver.ClassLoaderTemplateResolver;
import org.xhtmlrenderer.pdf.ITextRenderer;

import java.io.FileOutputStream;
import java.io.OutputStream;

@Component
public class PdfGenerator {

    public PdfGenerator() {

    }

    public void generatePdfFromTemplate(User user, String templatePath, String outputPath) {
        try (OutputStream outputStream = new FileOutputStream(outputPath)) {
            Context context = new Context();
            context.setVariable("user", user);
            TemplateEngine templateEngine = new TemplateEngine();
            // 创建并配置模板解析器
            ClassLoaderTemplateResolver templateResolver = new ClassLoaderTemplateResolver();
            templateResolver.setPrefix("templates/");
            templateResolver.setSuffix(".html");
            templateResolver.setTemplateMode("HTML");
                // 将模板解析器设置到TemplateEngine中
            templateEngine.setTemplateResolver(templateResolver);
            String htmlContent = templateEngine.process(templatePath, context);

            ITextRenderer renderer = new ITextRenderer();
            renderer.setDocumentFromString(htmlContent);
            renderer.layout();
            renderer.createPDF(outputStream);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

使用

java 复制代码
        String templatePath = "template.html";
        String outputPath = "C:\\Temp\\aaa\\2024\\3\\12\\output.pdf";

        PdfGenerator pdfGenerator = new PdfGenerator();
        pdfGenerator.generatePdfFromTemplate(User.builder().name("ss").email("22").build(), templatePath, outputPath);
 

导出成功

出现的问题:如果HTML文件里面有js就会失败

相关推荐
千叶寻-1 小时前
正则表达式
前端·javascript·后端·架构·正则表达式·node.js
記億揺晃着的那天8 小时前
Vue + Element UI 表格自适应高度如何做?
javascript·vue.js·ui
无尽夏_8 小时前
HTML5(前端基础)
前端·html·html5
GISer_Jing9 小时前
ByteDance——jy真题
前端·javascript·面试
真的想不出名儿9 小时前
Vue 中 props 传递数据的坑
前端·javascript·vue.js
阳光阴郁大boy9 小时前
星座运势网站技术解析:从零打造现代化Web应用
前端·javascript
sorryhc9 小时前
如何设计一个架构良好的前端请求库?
前端·javascript·架构
Queen_sy9 小时前
vue3 el-date-picker 日期选择器校验规则-选择日期范围不能超过七天
javascript·vue.js·elementui
lvchaoq10 小时前
react 修复403页面无法在首页跳转问题
前端·javascript·react.js
郝开10 小时前
6. React useState基础使用:useState修改状态的规则;useState修改对象状态的规则
前端·javascript·react.js