批量生成不同用户的pdf 文件(html样式)

技术 selenium + thymeleaf + itextpdf + chromedriver

使用thymeleaf 将动态数据替换

使用selenium +chromedriver 进行js ,css等逻辑运算后渲染视图

使用itextpdf 将html 转为pdf 文件

html模板

xml 复制代码
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>My Page</title>
    <!-- 引入 jQuery 库 -->
    <script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
    <style>
        body {
            font-family: 'SimSun', 'SimHei', sans-serif;
        }
    </style>
    <!-- 引入 G2 库 -->
<!--    <script src="https://gw.alipayobjects.com/os/lib/antv/g2/4.1.16/dist/g2.min.js"></script>-->
</head>
<body>
<h1 th:text="${title}">cser</h1>
<div id="content"></div>
<script type="text/javascript" th:inline="javascript">
    /*<![CDATA[*/
         document.addEventListener('DOMContentLoaded', function() {
             $('#content').html(
                 "<select name='status'>"+
                 "   <option value='测试'>111</option>"+
                 "   <option value='测试2'>222</option>"+
                 "</select>")
             let titlenew = "测试"; // 确保这里赋值正确
             document.querySelector('h1').innerText = titlenew;
             document.title = titlenew; // 更新浏览器标签页的标题
         });
    /*]]>*/
</script>

</body>
</html>

执行代码

java 复制代码
public void generatePdf(HttpServletResponse response) throws IOException {
        // 设置 ChromeDriver 路径
        // 设置 ChromeDriver 路径
        System.setProperty("webdriver.chrome.driver", "D:/chromedriver.exe");
        // 初始化 WebDriver
        // 设置chrome选项
        ChromeOptions options = new ChromeOptions();
//        options.setBinary("D:\\chromedriver\\chrome/chrome.exe");
        options.setBinary("C:\\Chrome\\Application/chrome.exe");
        options.addArguments("--headless");
        options.addArguments("--disable-gpu");
        WebDriver driver = new ChromeDriver(options);


        // 动态数据
        Map<String, Object> data = new HashMap<>();
        data.put("title", "Hello, World!");
        data.put("condition", "true");
//        data.put("imagePath", imagePath); // 路径
        // 使用 Thymeleaf 渲染模板
        Context context = new Context();
        context.setVariables(data);
        String htmlContent = templateEngine.process("templates", context);

        try {
            driver.manage().timeouts().implicitlyWait(Duration.ofSeconds(60));
            // 将 htmlContent 进行 Base64 编码
            byte[] base64EncodedBytes = Base64.getEncoder().encode(htmlContent.getBytes(StandardCharsets.UTF_8));
            String base64EncodedHtmlContent = new String(base64EncodedBytes);

            // 构建完整的 data URL
            htmlContent = "data:text/html;base64," + base64EncodedHtmlContent;
            // 加载HTML内容
//            htmlContent = "data:text/html;charset=utf-8," + encodedHtmlContent;

            driver.get(htmlContent);

            // 等待JavaScript执行完成
            Thread.sleep(3000); // 等待3秒,确保JavaScript执行完成

            //获取全部的html
            String pageSource = driver.getPageSource();
//            // 获取最终的HTML内容
//            WebElement body = driver.findElement(By.tagName("html"));
//            String renderedHtml = body.getAttribute("outerHTML");

            try (FileOutputStream outputStream = new FileOutputStream(filePath)) {
                // 使用字体文件路径创建字体对象
                String fontPath = "chromedriver/cs.TTF";
                FontProgram font = FontProgramFactory.createFont(fontPath);
                // 创建 DefaultFontProvider 并设置字体
                DefaultFontProvider fontProvider = new DefaultFontProvider(false, false, true);
                fontProvider.addFont(font);

                // 创建 ConverterProperties 并设置字体提供者
                ConverterProperties converterProperties = new ConverterProperties();
                converterProperties.setFontProvider(fontProvider);
                HtmlConverter.convertToPdf(pageSource, outputStream, converterProperties);

            } catch (Exception e) {
                e.printStackTrace();
            }

        } catch (InterruptedException e) {
            driver.close();
        }

    }

pom 依赖

xml 复制代码
		<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
<!-- https://mvnrepository.com/artifact/org.seleniumhq.selenium/selenium-java -->
        <dependency>
            <groupId>org.seleniumhq.selenium</groupId>
            <artifactId>selenium-java</artifactId>
            <version>4.27.0</version>
        </dependency>

        <dependency>
            <groupId>org.seleniumhq.selenium</groupId>
            <artifactId>selenium-chrome-driver</artifactId>
            <version>4.27.0</version> <!-- 确保与 selenium-java 版本一致 -->
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.seleniumhq.selenium/selenium-remote-driver -->
        <dependency>
            <groupId>org.seleniumhq.selenium</groupId>
            <artifactId>selenium-remote-driver</artifactId>
            <version>4.27.0</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.seleniumhq.selenium/selenium-api -->
        <dependency>
            <groupId>org.seleniumhq.selenium</groupId>
            <artifactId>selenium-api</artifactId>
            <version>4.27.0</version>
        </dependency>
        <dependency>
            <groupId>com.itextpdf</groupId>
            <artifactId>itextpdf</artifactId>
            <version>5.5.11</version>
        </dependency>
相关推荐
阿幸软件杂货间9 分钟前
谷歌浏览器(Google Chrome)136.0.7103.93便携增强版|Win中文|安装教程
前端·chrome
双叶83615 分钟前
(C语言)超市管理系统 (正式版)(指针)(数据结构)(清屏操作)(文件读写)(网页版预告)(html)(js)(json)
c语言·javascript·数据结构·html·json
繁依Fanyi39 分钟前
Animaster:一次由 CodeBuddy 主导的 CSS 动画编辑器诞生记
android·前端·css·编辑器·codebuddy首席试玩官
想起你的日子1 小时前
Android studio 实现弹出表单编辑界面
java·前端·android studio
LuckyLay2 小时前
Vue百日学习计划Day9-15天详细计划-Gemini版
前端·vue.js·学习
码农黛兮_465 小时前
4. 文字效果/2D-3D转换 - 3D翻转卡片
3d·html·css3
水银嘻嘻8 小时前
12 web 自动化之基于关键字+数据驱动-反射自动化框架搭建
运维·前端·自动化
小嘟嚷ovo8 小时前
h5,原生html,echarts关系网实现
前端·html·echarts
十一吖i9 小时前
Vue3项目使用ElDrawer后select方法不生效
前端
只可远观9 小时前
Flutter目录结构介绍、入口、Widget、Center组件、Text组件、MaterialApp组件、Scaffold组件
前端·flutter