java依照模板导出PDF(利用itext)

作者:杏彩彩票app下载

java根据模板导出pdf,java模板导出pdf

   在网上看了一些Java生成pdf文件的,写的有点乱,有的不支持写入中文字体,有的不支持模板,有的只是随便把数据放里面生成文件,完全不考虑数据怎样放置的以及以后的维护性,想想还是自己总结一个完全版的导出pdf的工具类吧,总结一下网上的方法,加上自己的完善。具有以下特点:

综合特点:

    一对一,点对点的给对应的地方写值,比如模板里面放了个name标识,在程序里把“张三”赋给name,那么输出的pdf里面name的地方就变成了张三,准确方便快捷

    支持中文,可以使用自己下载的字体。

    支持图片:图片的大小范围可以在模板随意调,生成出来的图片不会超过范围。而且不需要根据坐标去算,程序里面自动计算的。

    支持多页模板,即使是好几页的模板,只要每个变量对应的范围确定好了,生成出来的格式就不会错乱。

 

先放个效果图:

 

   图片 1

 

下面是详细的步骤:

1.首先,新建一个word文档,内容如下,另存为pdf格式,我的命名:mytest.pdf。    

    图片 2

 

 

2.用Adobe Acrobat Pro 打开刚刚制作的pdf文件。如下图: 

    图片 3

 

3.点击创建-->PDF表单-->使用当前文档-->使用当前文档,一直点下一步完成。(有的版本Adobe Acrobat Pro软件右边有准备表单,直接点击准备表单是同样的效果)

 

    图片 4

   图片 5  图片 6

  图片 7

 

 

 

4.上面好多给框,双击黑框可以修改名称,还可以设置字体大小,如下图

    图片 8图片 9

 

 

 5.图片的地方没有黑框,我们可以在空白处点击右键,选择文本域,给图片的域起名为img。

图片 10

图片 11

图片 12

 

 

6.如下图是制作好的pdf模板,直接保存即可。注意:黑框里面的名称,是后面程序要用到的,程序根据名称给对应的位置赋值的。不管你去什么名字,只要保证和程序里面的名字一直即可。

图片 13

 

 7.pom.xml文件:

        <dependency>
            <groupId>com.itextpdf</groupId>
            <artifactId>itextpdf</artifactId>
            <version>5.4.3</version>
        </dependency>    

 

 

8.工具类文件:

我的模板是放在C盘下面的,所以路径是C:/mytest.pdf,另外,我还在C盘下面放了一张图片 c:/50336.jpg ,字体使用的是系统的字体,也可以自己到网上下载自己喜欢的字体文件,路径指向自己下载的字体文件路径即可

 

package wp.util;

import java.io.ByteArrayOutputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

import com.itextpdf.text.*;
import com.itextpdf.text.pdf.*;
/**
 * Created by wangpeng on 2018/02/01.
 */
public class PdfUtils {
    // 利用模板生成pdf  
    public static void pdfout(Map<String,Object> o) {
        // 模板路径  
        String templatePath = "C:/mytest.pdf";
        // 生成的新文件路径  
        String newPDFPath = "C:/testout1.pdf";

        PdfReader reader;
        FileOutputStream out;
        ByteArrayOutputStream bos;
        PdfStamper stamper;
        try {
            BaseFont bf = BaseFont.createFont("c://windows//fonts//simsun.ttc,1" , BaseFont.IDENTITY_H, BaseFont.EMBEDDED);
            Font FontChinese = new Font(bf, 5, Font.NORMAL);
            out = new FileOutputStream(newPDFPath);// 输出流
            reader = new PdfReader(templatePath);// 读取pdf模板  
            bos = new ByteArrayOutputStream();
            stamper = new PdfStamper(reader, bos);
            AcroFields form = stamper.getAcroFields();
            //文字类的内容处理
            Map<String,String> datemap = (Map<String,String>)o.get("datemap");
            form.addSubstitutionFont(bf);
            for(String key : datemap.keySet()){
                String value = datemap.get(key);
                form.setField(key,value);
            }
            //图片类的内容处理
            Map<String,String> imgmap = (Map<String,String>)o.get("imgmap");
            for(String key : imgmap.keySet()) {
                String value = imgmap.get(key);
                String imgpath = value;
                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(imgpath);
                //获取图片页面
                PdfContentByte under = stamper.getOverContent(pageNo);
                //图片大小自适应
                image.scaleToFit(signRect.getWidth(), signRect.getHeight());
                //添加图片
                image.setAbsolutePosition(x, y);
                under.addImage(image);
            }
            stamper.setFormFlattening(true);// 如果为false,生成的PDF文件可以编辑,如果为true,生成的PDF文件不可以编辑
            stamper.close();
            Document doc = new Document();
            Font font = new Font(bf, 32);
            PdfCopy copy = new PdfCopy(doc, out);
            doc.open();
            PdfImportedPage importPage = copy.getImportedPage(new PdfReader(bos.toByteArray()), 1);
            copy.addPage(importPage);
            doc.close();

        } catch (IOException e) {
            System.out.println(e);
        } catch (DocumentException e) {
            System.out.println(e);
        }

    }

    public static void main(String[] args) {
        Map<String,String> map = new HashMap();
        map.put("name","张三");
        map.put("creatdate","2018年1月1日");
        map.put("weather","晴朗");
        map.put("sports","打羽毛球");

        Map<String,String> map2 = new HashMap();
        map2.put("img","c:/50336.jpg");

        Map<String,Object> o=new HashMap();
        o.put("datemap",map);
        o.put("imgmap",map2);
        pdfout(o);
    }
}  

 

9.效果图如下:

 图片 14

 

如有新的需求功能需要完善,我会后续补充在这里。

在网上看了一些Java生成pdf文件的,写的有点乱,有的不支持写入中文字体,有的不支持模板,有的只是...

一、制作模板

springMVC(3)---利用pdf模板下载

          在实际开发中,很多时候需要通过把数据库中的数据添加到pdf模板中,然后供客户下载,那我们该如何中呢?

           本文主要内容是:用java在pdf模板中加入数据,图片

            直接举例:

           第一步,对pdf模板添加文本域                   

         使用Adobe Acrobat  Pro软件,选择表单,就可以添加文本域很简单。这里也可以设置字体大小,是否换行等

       图片 15

     第二步、pom文件导入相关jar包                           

 <!--  注意:我一开始把这个放到pom.xml文件中,发现报错了,原因是我的本地mevan库中没有5.5.10版的,只有5.1.1和5.1.3于是我在网上下了个,再放到本地库,更新下项目就可以了 -->
 <!-- itext 图片转pdf -->
        <dependency>
            <groupId>com.itextpdf</groupId>
            <artifactId>itextpdf</artifactId>
            <version>5.5.10</version>
        </dependency>

      第二步,把pdf和照片素材放到项目中                      

      这里我在resources下面新建了pdf文件夹,放到这里面          

 图片 16

        第三步、PdfController.java                              

import java.io.OutputStream;
import java.io.UnsupportedEncodingException;
import java.net.URLEncoder;
import java.util.HashMap;
import java.util.Map;

import javax.servlet.http.HttpServletResponse;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

import com.itextpdf.text.Image;
import com.itextpdf.text.Rectangle;
import com.itextpdf.text.pdf.AcroFields;
import com.itextpdf.text.pdf.BaseFont;
import com.itextpdf.text.pdf.PdfContentByte;
import com.itextpdf.text.pdf.PdfReader;
import com.itextpdf.text.pdf.PdfStamper;

@Controller
@RequestMapping("/jsp/exportpdf")
public class PdfController {

    @RequestMapping
    public String pdfexport(HttpServletResponse response) {
        // 指定解析器
        System.setProperty("javax.xml.parsers.DocumentBuilderFactory",
                "com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderFactoryImpl");

        String filename = "resume.pdf";

        response.setContentType("application/pdf");
        try {
            //设置文件头:最后一个参数是设置下载文件名(这里我们叫:个人简历.pdf)
            response.setHeader("Content-Disposition", "attachment;fileName=" + URLEncoder.encode("个人简历.pdf", "UTF-8"));
        } catch (UnsupportedEncodingException e1) {
            e1.printStackTrace();
        }
        OutputStream os = null;
        PdfStamper ps = null;
        PdfReader reader = null;
        try {
            os = response.getOutputStream(); // 生成的新文件路径 ,这里指页面
            /**
             * class.getResource("/") --> 返回class文件所在的顶级目录,一般为包名的顶级目录
             * 在这个目录中src/main/java和src/main/resources和src/test/java都是属于顶级目录
             * 这里pdf/就属于顶级目录下的子目录了
             * 
             */
            // 2 读入pdf表单
            reader = new PdfReader(PdfController.class.getResource("/pdf/") + "resume.pdf");

            // 3 根据表单生成一个新的pdf
            ps = new PdfStamper(reader, os);

            // 4 获取pdf表单中所有字段
            AcroFields form = ps.getAcroFields();

            // 5给表单添加中文字体 这里采用系统字体。不设置的话,中文可能无法显示
            BaseFont bf = BaseFont.createFont("C:/WINDOWS/Fonts/SIMSUN.TTC,1", BaseFont.IDENTITY_H, BaseFont.EMBEDDED);
            form.addSubstitutionFont(bf);

            // 6查询数据
            Map<String, Object> data = new HashMap<String, Object>();
            data.put("xh", "1021229");
            data.put("xm", "徐小筱");

            // 7遍历data 给pdf表单表格赋值
            for (String key : data.keySet()) {
                form.setFieldProperty(key, "textfont", bf, null);// 设置字体
                form.setField(key, data.get(key).toString());
            }

            // 如果为false那么生成的PDF文件还能编辑,一定要设为true  
            ps.setFormFlattening(true);


            //添加图片: 通过域名获取所在页和坐标,左下角为起点

            int pageNo = form.getFieldPositions("zp").get(0).page;
            Rectangle signRect = form.getFieldPositions("zp").get(0).position;
            float x = signRect.getLeft();
            float y = signRect.getBottom();

            // 读图片
            String imgpath = PdfController.class.getResource("/pdf/") + "zhaopian.jpg";
            Image image = Image.getInstance(imgpath);

            // 获取操作的页面
            PdfContentByte under = ps.getOverContent(pageNo);

            // 根据域的大小缩放图片
            image.scaleToFit(signRect.getWidth(), signRect.getHeight());
            // 添加图片
            image.setAbsolutePosition(x, y);
            under.addImage(image);

            System.out.println("===============PDF导出成功=============");
        } catch (Exception e) {
            System.out.println("===============PDF导出失败=============");
            e.printStackTrace();
        } finally {
            try {
                ps.close();
                reader.close();
                os.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }

        return null;
    }

}

          第四步、jsp文件映射到Controller层           

         只要点击下载,文件就自动下载了

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<html>
<body>
<form action="exportpdf">
        <input type="submit" value="下载">
    </form>
</body>
</html>

  最终结果:完美!

图片 17

 

 想的太多,做的太少,中间的落差就是烦恼,要么去做,要么别想 少尉【10】**

 

    1.下载Adobe Acrobat 9 Pro软件(pdf编辑器),制作模板必须使用该工具。

    2.下载itextpdf-5.5.5.jar、itext-asian-5.2.0.jar两个jar包。(说明:itextpdf-5.5.5.jar用于操作pdf;itext-asian-5.2.0.jar用于pdf中文处理)

    3.新建word文档,根据项目需求制作模板,然后另存为pdf格式的文件。

    4.Adobe Acrobat 9 Pro软件打开pdf模板文件,点击‘‘表单’’--“启动表单向导”--引入pdf模板文件--添加表单域或者在自动识别的表单域设置表单域名称。设置完成后保存pdf模板。

 模板设置如图所示:

本文由杏彩发布,转载请注明来源

关键词: