JAVA导出pdf - 超高效

有小老弟网上扒的PDF导出,效率之低,给我惊讶到了…画Freemarker模板给我看的…
什么?

1、绘制导出模板

😺 打开WPS或者Word

😺 1点击插入,2选择形状

在这里插入图片描述

😺 选择矩形或者线条进行绘制,自由绘制线粗细及背景色

在这里插入图片描述

😺 以下为绘制好的示范模板:

在这里插入图片描述

😺 把word转换为pdf再导入Adobe_Acrobat_X_Pro

在这里插入图片描述

😺 添加新域

在这里插入图片描述

😺 选择文本域就能满足大多数情况,看具体模板需求

在这里插入图片描述

😺 直接把域放在模板对应位置即可

在这里插入图片描述

😺 文本域属性调整

在这里插入图片描述

😺 域处理完毕之后,重新保存为PDF即可

在这里插入图片描述

代码处理

😺 依赖

<!-- pdf模板导出 -->
<dependency>
    <groupId>com.itextpdf</groupId>
    <artifactId>itextpdf</artifactId>
    <version>5.5.6</version>
</dependency>
<dependency>
    <groupId>com.itextpdf</groupId>
    <artifactId>itext-asian</artifactId>
    <version>5.2.0</version>
</dependency>

😺 控制层

/**
     * pdf导出
     *
     * @throws Exception
     * @author 摸鱼码长
     */
    @GetMapping("/pdf_export")
    @ApiOperation(value = "pdf导出")
    public void printPdf(HttpServletResponse response) throws Exception {

        // 获取数据源
        HashMap data = new HashMap<>();
        data.put("Text1", "value");

        String downloadName = "林深不见鹿.pdf";

        String templatePath = "/thisIsExUrl";

        OutputStream outputStream = null;

        try {
            response.setContentType("application/pdf");
            response.setCharacterEncoding("UTF-8");
            response.setHeader("Content-Disposition", "inline;fileName=" + URLEncoder.encode(downloadName, "UTF-8"));  // 预览
            // 获取outputStream
            outputStream = response.getOutputStream();
            // 生成pdf流输出到response
            ItextPdfUtil.generatePDF(templatePath, outputStream, data);
        } catch (Exception e) {
            log.error("-===== ::: something ERROR ", e);
            throw new RuntimeException("Buz log ..");
        } finally {
            if (outputStream != null) {
                outputStream.close();
            }
        }
    }

😺 核心方法

    /**
     * 生成pdf流输出到response
     *
     * @param templatePdfPath url
     * @param outputStream    outputStream
     * @param data            dataResource
     * @author 摸鱼码长
     */
    public static void generatePDF(String templatePdfPath, OutputStream outputStream, HashMap data) {
        ByteArrayOutputStream byteArrayOutputStream = null;
        PdfReader reader = null;
        try {
            PdfReader.unethicalreading = true;
            reader = new PdfReader(templatePdfPath);
            byteArrayOutputStream = new ByteArrayOutputStream();
            PdfStamper ps = new PdfStamper(reader, byteArrayOutputStream);

            ArrayList<BaseFont> fontList = new ArrayList<>();
            AcroFields fields = ps.getAcroFields();
            fields.setGenerateAppearances(true);
            fields.setSubstitutionFonts(fontList);
            transformRegular(ps, fields, data);
            ps.setFormFlattening(true);
            ps.close();
            reader.close();
            outputStream.write(byteArrayOutputStream.toByteArray());
            outputStream.flush();
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            if (reader != null) {
                try {
                    reader.close();
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
            if (byteArrayOutputStream != null) {
                try {
                    byteArrayOutputStream.close();
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }
    }

    /**
     * 表单域填充
     *
     * @param stamper
     * @param form
     * @param dataMap
     * @throws IOException
     * @throws DocumentException
     * @author 摸鱼码长
     */
    public static void transformRegular(PdfStamper stamper, AcroFields form, HashMap dataMap) throws IOException, DocumentException {
        if (dataMap == null || dataMap.size() == 0) {
            return;
        }
        // 设置中文显示
        BaseFont bfChinese = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED);
        String key = "";
        form.addSubstitutionFont(bfChinese);
        Iterator ekey = dataMap.keySet().iterator();
        while (ekey.hasNext()) {
            key = ekey.next().toString();
            try {
                //非空放入
                if (dataMap.get(key) != null) {
                    if (dataMap.get(key) instanceof HashMap) {
                        HashMap<String, String> fieldMap = (HashMap<String, String>) dataMap.get(key);
                        if ("img".equals(fieldMap.get("type"))) {
                            String content = fieldMap.get("content");
                            //如果图片地址为空,或不存在则不填充
                            if (StringUtils.isBlank(content)) {
                                continue;
                            }
                            URL url = new URL(content);
                            if ("file".equals(url.getProtocol())) {
                                if (!new File(url.toURI()).exists()) {
                                    continue;
                                }
                            }
                            // 通过域名获取所在页和坐标,左下角为起点
                            int pageNo = form.getFieldPositions(key).get(0).page;
                            Rectangle signRect = form.getFieldPositions(key).get(0).position;
                            float x = signRect.getLeft();
                            float y = signRect.getBottom();
                            // 读图片
                            Image image = Image.getInstance(content);
                            // 获取操作的页面
                            PdfContentByte under = stamper.getOverContent(pageNo);
                            // 根据域的大小缩放图片
                            image.scaleToFit(signRect.getWidth(), signRect.getHeight());
                            // 添加图片
                            image.setAbsolutePosition(x, y);
                            under.addImage(image);
                        }
                    } else {
                        form.setField(key, dataMap.get(key).toString());
                    }

                }
            } catch (IOException e) {
                e.printStackTrace();
            } catch (DocumentException e) {
                e.printStackTrace();
            } catch (URISyntaxException e) {
                throw new RuntimeException(e);
            }
        }
    }
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: aspose-pdf-21.6.jar是一个用于处理PDF文档的Java库。它提供了丰富的功能和方法,可以让开发人员在Java应用程序中轻松地创建、编辑和转换PDF文档。 使用aspose-pdf-21.6.jar,可以使用简单的代码来生成PDF文档,包括创建页面、添加文本、图像、表格和其他元素。开发人员可以通过设置字体、颜色和样式来自定义文本内容,还可以添加书签、链接和注释来增强PDF文档的交互性。 除了创建PDF文档,aspose-pdf-21.6.jar还支持PDF文档的编辑和操作。它可以很容易地提取和修改PDF文档中的文本、图像和其他元素,还可以对页面布局进行更改、旋转和平移操作。此外,开发人员还可以使用aspose-pdf-21.6.jar对现有的PDF文档进行合并、拆分和删除页面等操作。 aspose-pdf-21.6.jar还提供了PDF文档的转换功能。开发人员可以使用它将PDF文档转换为其他格式,如图片、HTML和其他Office文档格式。反过来,aspose-pdf-21.6.jar也可以将其他格式的文件转换为PDF文档,以便在Java应用程序中进行处理和编辑。 总而言之,aspose-pdf-21.6.jar是一个功能强大的Java库,提供了丰富的功能和方法,使开发人员可以轻松地处理和操作PDF文档。无论是创建、编辑还是转换PDF文档,都可以使用aspose-pdf-21.6.jar快速实现。 ### 回答2: aspose-pdf-21.6.jar是一个用于处理PDF文件的Java库。它提供了许多功能,可以使开发人员更轻松地创建、编辑和转换PDF文档。 首先,aspose-pdf-21.6.jar可以用来创建PDF文档。开发人员可以使用该库的API来动态地生成包含文本、图像、表格和其他元素的PDF文档。可以设置文档的页面大小、边距和背景颜色,以及其他样式选项。 其次,aspose-pdf-21.6.jar还提供了丰富的编辑功能。开发人员可以使用该库来添加、删除和移动PDF文档中的页面、文本和图像。可以修改文本的字体、大小和颜色,以及图像的大小和位置。还可以插入链接、书签和水印等特性。 此外,aspose-pdf-21.6.jar还支持PDF文档的转换。开发人员可以使用该库将PDF文档转换为其他文件格式,如Word、Excel、PowerPoint和图像文件。同样,它也可以将其他文件格式转换为PDF。 使用aspose-pdf-21.6.jar,开发人员可以轻松地处理PDF文档,满足各种需求。不论是生成报告、创建电子书、实现业务流程自动化,还是进行数据导出和导入,该库都能提供便捷和高效的解决方案。 总的来说,aspose-pdf-21.6.jar是一个功能强大的Java库,能够处理PDF文档的创建、编辑和转换。它提供了丰富的功能和灵活的API,使开发人员能够高效地开发应用程序,满足各种PDF处理需求。 ### 回答3: aspose-pdf-21.6.jar是一个Java库,用于处理PDF文件。它提供了丰富的功能,包括创建、合并、拆分、加密和解密PDF文件,以及对PDF文档进行文本提取、图像提取和文本替换等操作。此外,它还支持设置PDF页面的大小、方向、页眉页脚、水印和书签等功能。 aspose-pdf-21.6.jar还提供了PDF表格的创建与编辑功能,可以方便地添加、删除和编辑表格数据,并支持设置表格的样式、边框和背景等属性。 此外,该库还支持将其他格式的文件(如Word、Excel和HTML)转换为PDF文件,方便用户将不同格式的文档统一转换为PDF进行保存或分享。 aspose-pdf-21.6.jar的使用非常灵活,适用于各种Java应用程序开发场景。无论是在企业文档处理、报表生成还是文档自动化处理等方面,都能发挥重要作用。 总之,aspose-pdf-21.6.jar是一个功能强大的PDF处理工具库,可以帮助开发人员轻松处理各种PDF文件操作需求,并提高开发效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值