java整合itext pdf实现固定模版pdf导出

java整合itext pdf实现固定模版pdf导出,通过自定义pdf模版,填充指定字段内容,将多个pdf文件压缩为zip文件响应

1、导入依赖

复制代码
        <!--       itex PDF -->
        <dependency>
            <groupId>com.itextpdf</groupId>
            <artifactId>itextpdf</artifactId>
            <version>5.5.13.3</version>
        </dependency>

2、编写PDF模版

使用WPS的PDF,插入表格来定义模板,通过wps的表单编辑功能输入参数

双击表格栏填写数据,后面写入的参数名称

最终模版样式:

📎reportTemplate0523.pdf

3、编写导出业务接口

先将模版文件放在resources目录的tempplate下

java 复制代码
@PostMapping("/reportExport")
public void exportElecProtocolBatch(@RequestBody StudentReportDto dto, HttpServletResponse response) {
try {

    // 查询业务数据
    IPage<SxReportVo> reportInfo = sxReportService.getReportStudentExportInfo(dto);
    if (reportInfo.getTotal() == 0) {
        return;
    }
    List<SxReportVo> records = reportInfo.getRecords();

    // 设置响应格式ZIP
    response.setContentType("application/zip");
    String zipFileName = URLEncoder.encode("实习报告.zip", "UTF-8");
    response.setHeader("Content-Disposition", "attachment; filename=" + zipFileName);

    // 向ZIP输出流写数据
    try (ZipOutputStream zipOut = new ZipOutputStream(response.getOutputStream())) {
        records.forEach(x -> {
            try {
                byte[] pdfBytes = generatePdf2(x);
                String pdfFileName = "实习报告_" + x.getReportTitle() +x.getReportStartdate()+ ".pdf";
                ZipEntry zipEntry = new ZipEntry(pdfFileName);
                zipOut.putNextEntry(zipEntry);
                zipOut.write(pdfBytes);
                zipOut.closeEntry();
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        });
    }
} catch (Exception e) {
    e.printStackTrace();
}
}


// 设置PDF模版及字段名
private byte[] generatePdf2(SxReportVo record) throws Exception {
    try (ByteArrayOutputStream bos = new ByteArrayOutputStream()) {
        PdfReader reader = new PdfReader(this.getClass().getResourceAsStream("/template/reportTemplate0523.pdf"));
        PdfStamper stamper = new PdfStamper(reader, bos);
        AcroFields form = stamper.getAcroFields();

        // 处理中文
        BaseFont bf = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.EMBEDDED);
        ArrayList<BaseFont> fontList = new ArrayList<>();
        fontList.add(bf);
        form.setSubstitutionFonts(fontList);

        Map<String, Object> data = new HashMap<>();
        data.put("studentUserName", record.getStudentUserName());
        data.put("studentUserCode", record.getStudentUserCode());
        data.put("grade", record.getGrade());
        data.put("className", record.getClassName());
        data.put("majorName", record.getMajorName());
        data.put("collegeName", record.getCollegeName());
        data.put("teacherName", record.getTeacherName());
        data.put("createTime", record.getCreateTime());
        data.put("reportStartdate", record.getReportStartdate());
        data.put("reportTitle", record.getReportTitle());
        data.put("reportContent", record.getReportContent());
        data.put("reportImage", record.getReportImage());
        data.put("reportReview", record.getReportReview());
        data.put("reportXscore", record.getReportXscore());

        for (Map.Entry<String, Object> entry : data.entrySet()) {
            if (entry.getKey().contains("student")) {
                form.setField(entry.getKey(), ObjectUtil.isNotEmpty(entry.getValue()) ? entry.getValue().toString() : "", true);
            } else {
                form.setField(entry.getKey(), ObjectUtil.isNotEmpty(entry.getValue()) ? entry.getValue().toString() : "");
          }
       }

       stamper.setFormFlattening(true);
       stamper.close();
       return bos.toByteArray();
    }
}

4、测试导出

相关推荐
User_芊芊君子10 小时前
CANN010:PyASC Python编程接口—简化AI算子开发的Python框架
开发语言·人工智能·python
苏渡苇10 小时前
优雅应对异常,从“try-catch堆砌”到“设计驱动”
java·后端·设计模式·学习方法·责任链模式
团子的二进制世界10 小时前
G1垃圾收集器是如何工作的?
java·jvm·算法
白日做梦Q10 小时前
Anchor-free检测器全解析:CenterNet vs FCOS
python·深度学习·神经网络·目标检测·机器学习
long31610 小时前
Aho-Corasick 模式搜索算法
java·数据结构·spring boot·后端·算法·排序算法
喵手10 小时前
Python爬虫实战:公共自行车站点智能采集系统 - 从零构建生产级爬虫的完整实战(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集公共自行车站点·公共自行车站点智能采集系统·采集公共自行车站点导出csv
喵手11 小时前
Python爬虫实战:地图 POI + 行政区反查实战 - 商圈热力数据准备完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·地区poi·行政区反查·商圈热力数据采集
熊猫_豆豆11 小时前
YOLOP车道检测
人工智能·python·算法
rannn_11111 小时前
【苍穹外卖|Day4】套餐页面开发(新增套餐、分页查询、删除套餐、修改套餐、起售停售)
java·spring boot·后端·学习
nimadan1211 小时前
**热门短剧小说扫榜工具2025推荐,精准捕捉爆款趋势与流量
人工智能·python