Html转换PDF(Java实用版)

前言:

在工作当中,遇到了需要把HTML页面转化为PDF文档,有很多中实现,如下进行一个对比,大家个借鉴去进行使用

各实现对比表

于Windows平台进行测试:

Html转换PDF(Java实用版)

此博客仅基于IText和基于WKHtmlToPdf来介绍并使用,均为博主亲测

其他两个可自行研究哈

1、基于IText(推荐)

iText 是业界使用最为广泛的创建 PDF 的框架,从 iText 5 升级到 iText 7 后,功能模块的划分更加清晰,两者在使用上,有较为明显的区别。

此处就不进行区别的赘述了,直接上代码,本次使用的是iText7

1.1、引入依赖

注意两个依赖的版本对应,进入html2pdf的pom文件就能看到itext的版本,font-asian的版本最低也要是html2pdf中itext7的版本。

<!-- itext7html转pdf  -->
<dependency>
    <groupid>com.itextpdf</groupid>
    <artifactid>html2pdf</artifactid>
    <version>3.0.2</version>
</dependency>
<!-- 中文字体支持 -->
<dependency>
    <groupid>com.itextpdf</groupid>
    <artifactid>font-asian</artifactid>
    <version>7.1.13</version>
</dependency>

1.2、水印和页码

导出pdf一般是需要水印和页码的,我们只要实现com.itextpdf.kernel.events.IEventHandler接口就可以了

水印

水印代码

/**
 * &#x6C34;&#x5370;
 */
public class WaterMarkEventHandler implements IEventHandler {

    /**
     * &#x6C34;&#x5370;&#x5185;&#x5BB9;
     */
    private String waterMarkContent;

    /**
     * &#x4E00;&#x9875;&#x4E2D;&#x6709;&#x51E0;&#x5217;&#x6C34;&#x5370;
     */
    private int waterMarkX;

    /**
     * &#x4E00;&#x9875;&#x4E2D;&#x6BCF;&#x5217;&#x6709;&#x591A;&#x5C11;&#x6C34;&#x5370;
     */
    private int waterMarkY;

    public WaterMarkEventHandler(String waterMarkContent) {
        this(waterMarkContent, 5, 5);
    }

    public WaterMarkEventHandler(String waterMarkContent, int waterMarkX, int waterMarkY) {
        this.waterMarkContent = waterMarkContent;
        this.waterMarkX = waterMarkX;
        this.waterMarkY = waterMarkY;
    }

    @Override
    public void handleEvent(Event event) {

        PdfDocumentEvent documentEvent = (PdfDocumentEvent) event;
        PdfDocument document = documentEvent.getDocument();
        PdfPage page = documentEvent.getPage();
        Rectangle pageSize = page.getPageSize();

        PdfFont pdfFont = null;
        try {
            pdfFont = PdfFontFactory.createFont("STSongStd-Light", "UniGB-UCS2-H", false);
        } catch (IOException e) {
            e.printStackTrace();
        }

        PdfCanvas pdfCanvas = new PdfCanvas(page.newContentStreamAfter(), page.getResources(), document);

        Paragraph waterMark = new Paragraph(waterMarkContent).setOpacity(0.5f);
        Canvas canvas = new Canvas(pdfCanvas, pageSize)
            .setFontColor(WebColors.getRGBColor("lightgray"))
            .setFontSize(16)
            .setFont(pdfFont);

        for (int i = 0; i < waterMarkX; i++) {
            for (int j = 0; j < waterMarkY; j++) {
                canvas.showTextAligned(waterMark, (150 + i * 300), (160 + j * 150), document.getNumberOfPages(), TextAlignment.CENTER, VerticalAlignment.BOTTOM, 120);
            }
        }
        canvas.close();
    }
}

页码

页码代码

/**
 * &#x9875;&#x7801;
 */
public class PageEventHandler implements IEventHandler {

    @Override
    public void handleEvent(Event event) {
        PdfDocumentEvent documentEvent = (PdfDocumentEvent) event;
        PdfDocument document = documentEvent.getDocument();
        PdfPage page = documentEvent.getPage();
        Rectangle pageSize = page.getPageSize();

        PdfFont pdfFont = null;
        try {
            pdfFont = PdfFontFactory.createFont("STSongStd-Light", "UniGB-UCS2-H", false);
        } catch (IOException e) {
            e.printStackTrace();
        }

        PdfCanvas pdfCanvas = new PdfCanvas(page.getLastContentStream(), page.getResources(), document);
        Canvas canvas = new Canvas(pdfCanvas, pageSize);
        float  x = (pageSize.getLeft() + pageSize.getRight()) / 2;
        float  y = pageSize.getBottom() + 15;
        Paragraph paragraph = new Paragraph("&#x7B2C;" + document.getPageNumber(page) + "&#x9875;/&#x5171;" + document.getNumberOfPages() + "&#x9875;")
            .setFontSize(10)
            .setFont(pdfFont);
        canvas.showTextAligned(paragraph, x, y, TextAlignment.CENTER);
        canvas.close();
    }
}

1.3、转换工具类

转换工具类

/**
 * Itext7&#x8F6C;&#x6362;&#x5DE5;&#x5177;&#x7C7B;
 */
@Slf4j
public class HtmlToPdfUtils {

    /**
     * html&#x8F6C;pdf
     *
     * @param inputStream  &#x8F93;&#x5165;&#x6D41;
     * @param waterMark    &#x6C34;&#x5370;
     * @param fontPath     &#x5B57;&#x4F53;&#x8DEF;&#x5F84;&#xFF0C;ttc&#x540E;&#x7F00;&#x7684;&#x5B57;&#x4F53;&#x9700;&#x8981;&#x6DFB;&#x52A0;<b>,0<b>
     * @param outputStream &#x8F93;&#x51FA;&#x6D41;
     * @date : 2021/1/15 14:07
     */
    public static void convertToPdf(InputStream inputStream, String waterMark, String fontPath, OutputStream outputStream) throws IOException {

        PdfWriter pdfWriter = new PdfWriter(outputStream);
        PdfDocument pdfDocument = new PdfDocument(pdfWriter);
        //&#x8BBE;&#x7F6E;&#x4E3A;A4&#x5927;&#x5C0F;
        pdfDocument.setDefaultPageSize(PageSize.A4);
        //&#x6DFB;&#x52A0;&#x6C34;&#x5370;
        pdfDocument.addEventHandler(PdfDocumentEvent.END_PAGE, new WaterMarkEventHandler(waterMark));

        //&#x6DFB;&#x52A0;&#x4E2D;&#x6587;&#x5B57;&#x4F53;&#x652F;&#x6301;
        ConverterProperties properties = new ConverterProperties();
        FontProvider fontProvider = new FontProvider();

        //        &#x8BBE;&#x7F6E;&#x5B57;&#x4F53;
        /*PdfFont sysFont = PdfFontFactory.createFont("STSongStd-Light", "UniGB-UCS2-H", false);
        fontProvider.addFont(sysFont.getFontProgram(), "UniGB-UCS2-H");*/

        //&#x6DFB;&#x52A0;&#x81EA;&#x5B9A;&#x4E49;&#x5B57;&#x4F53;&#xFF0C;&#x4F8B;&#x5982;&#x5FAE;&#x8F6F;&#x96C5;&#x9ED1;
        if (StringUtils.isNotBlank(fontPath)) {
            PdfFont microsoft = PdfFontFactory.createFont(fontPath, PdfEncodings.IDENTITY_H, false);
            fontProvider.addFont(microsoft.getFontProgram(), PdfEncodings.IDENTITY_H);
        }

        properties.setFontProvider(fontProvider);
        //        &#x8BFB;&#x53D6;Html&#x6587;&#x4EF6;&#x6D41;&#xFF0C;&#x67E5;&#x627E;&#x51FA;&#x5F53;&#x4E2D;&#x7684;&#xA0;&#x6216;&#x51FA;&#x73B0;&#x7C7B;&#x4F3C;&#x7684;&#x7B26;&#x53F7;&#x7A7A;&#x683C;&#x5B57;&#x7B26;
        inputStream = readInputStrem(inputStream);
        if (inputStream != null) {
            //        &#x751F;&#x6210;pdf&#x6587;&#x6863;
            HtmlConverter.convertToPdf(inputStream, pdfDocument, properties);
            pdfWriter.close();
            pdfDocument.close();
            return;
        } else {
            log.error("&#x8F6C;&#x6362;&#x5931;&#x8D25;&#xFF01;");
        }
    }

    /**
     * &#x8BFB;&#x53D6;HTML &#x6D41;&#x6587;&#x4EF6;&#xFF0C;&#x5E76;&#x67E5;&#x8BE2;&#x5F53;&#x4E2D;&#x7684;&#xA0;&#x6216;&#x7C7B;&#x4F3C;&#x7B26;&#x53F7;&#x76F4;&#x63A5;&#x66FF;&#x6362;&#x4E3A;&#x7A7A;&#x683C;
     *
     * @param inputStream
     * @return
     */
    private static InputStream readInputStrem(InputStream inputStream) {
        // &#x5B9A;&#x4E49;&#x4E00;&#x4E9B;&#x7279;&#x6B8A;&#x5B57;&#x7B26;&#x7684;&#x6B63;&#x5219;&#x8868;&#x8FBE;&#x5F0F; &#x5982;&#xFF1A;
        String regEx_special = "\\&[a-zA-Z]{1,10};";
        try {
            //<1>&#x521B;&#x5EFA;&#x5B57;&#x8282;&#x6570;&#x7EC4;&#x8F93;&#x51FA;&#x6D41;&#xFF0C;&#x7528;&#x6765;&#x8F93;&#x51FA;&#x8BFB;&#x53D6;&#x5230;&#x7684;&#x5185;&#x5BB9;
            ByteArrayOutputStream baos = new ByteArrayOutputStream();
            //<2>&#x521B;&#x5EFA;&#x7F13;&#x5B58;&#x5927;&#x5C0F;
            byte[] buffer = new byte[1024]; // 1KB
            //&#x6BCF;&#x6B21;&#x8BFB;&#x53D6;&#x5230;&#x5185;&#x5BB9;&#x7684;&#x957F;&#x5EA6;
            int len = -1;
            //<3>&#x5F00;&#x59CB;&#x8BFB;&#x53D6;&#x8F93;&#x5165;&#x6D41;&#x4E2D;&#x7684;&#x5185;&#x5BB9;
            while ((len = inputStream.read(buffer)) != -1) { //&#x5F53;&#x7B49;&#x4E8E;-1&#x8BF4;&#x660E;&#x6CA1;&#x6709;&#x6570;&#x636E;&#x53EF;&#x4EE5;&#x8BFB;&#x53D6;&#x4E86;
                baos.write(buffer, 0, len);   //&#x628A;&#x8BFB;&#x53D6;&#x5230;&#x7684;&#x5185;&#x5BB9;&#x5199;&#x5230;&#x8F93;&#x51FA;&#x6D41;&#x4E2D;
            }
            //<4> &#x628A;&#x5B57;&#x8282;&#x6570;&#x7EC4;&#x8F6C;&#x6362;&#x4E3A;&#x5B57;&#x7B26;&#x4E32;
            String content = baos.toString();
            //<5>&#x5173;&#x95ED;&#x8F93;&#x5165;&#x6D41;&#x548C;&#x8F93;&#x51FA;&#x6D41;
            //            inputStream.close();
            baos.close();
            //            log.info("&#x8BFB;&#x53D6;&#x7684;&#x5185;&#x5BB9;&#xFF1A;{}", content);
            //            &#x5224;&#x65AD;HTML&#x5185;&#x5BB9;&#x662F;&#x5426;&#x5177;&#x6709;HTML&#x7684;&#x7279;&#x6B8A;&#x5B57;&#x7B26;&#x6807;&#x8BB0;
            Pattern compile = Pattern.compile(regEx_special, Pattern.CASE_INSENSITIVE);
            Matcher matcher = compile.matcher(content);
            String replaceAll = matcher.replaceAll("");
            //            log.info("&#x66FF;&#x6362;&#x540E;&#x7684;&#x5185;&#x5BB9;&#xFF1A;{}", replaceAll);
            //            &#x5C06;&#x5B57;&#x7B26;&#x4E32;&#x8F6C;&#x5316;&#x4E3A;&#x8F93;&#x5165;&#x6D41;&#x8FD4;&#x56DE;
            InputStream stringStream = getStringStream(replaceAll);
            //<6>&#x8FD4;&#x56DE;&#x7ED3;&#x679C;
            return stringStream;
        } catch (Exception e) {
            e.printStackTrace();
            log.error("&#x9519;&#x8BEF;&#x4FE1;&#x606F;&#xFF1A;{}", e.getMessage());
            return null;
        }
    }

    /**
     * &#x5C06;&#x4E00;&#x4E2A;&#x5B57;&#x7B26;&#x4E32;&#x8F6C;&#x5316;&#x4E3A;&#x8F93;&#x5165;&#x6D41;
     * @param sInputString &#x5B57;&#x7B26;&#x4E32;
     * @return
     */
    public static InputStream getStringStream(String sInputString) {
        if (sInputString != null && !sInputString.trim().equals("")) {
            try {
                ByteArrayInputStream tInputStringStream = new ByteArrayInputStream(sInputString.getBytes());
                return tInputStringStream;
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        return null;
    }

}</6></5></4></3></2></1></b></b>

1.4、测试类

测试代码

@Slf4j
public class Test {

    public static void main(String[] args) throws IOException {
        long startTime = System.currentTimeMillis();
        //       html&#x6587;&#x4EF6;&#x6240;&#x5728;&#x76F8;&#x5BF9;&#x8DEF;&#x5F84;
        String htmlFile = "src/main/resources/html/index2.html";
        //       pdf&#x6587;&#x4EF6;&#x5B58;&#x50A8;&#x76F8;&#x5BF9;&#x8DEF;&#x5F84;
        String pdfFile = "src/main/resources/x6.pdf";
        //        &#x81EA;&#x5B9A;&#x4E49;&#x6C34;&#x5370;
        String waterMarkText =  "";
        InputStream inputStream = new FileInputStream(htmlFile);
        OutputStream outputStream = new FileOutputStream(pdfFile);
        //&#x5FAE;&#x8F6F;&#x96C5;&#x9ED1;&#x5728;windows&#x7CFB;&#x7EDF;&#x91CC;&#x7684;&#x4F4D;&#x7F6E;&#x5982;&#x4E0B;&#xFF0C;linux&#x7CFB;&#x7EDF;&#x76F4;&#x63A5;&#x62F7;&#x8D1D;&#x8BE5;&#x6587;&#x4EF6;&#x653E;&#x5728;linux&#x76EE;&#x5F55;&#x4E0B;&#x5373;&#x53EF;
        //        String fontPath = "src/main/resources/font/STHeiti Light.ttc,0";
        String fontPath = "src/main/resources/font/simsun.ttc,0";
        HtmlToPdfUtils.convertToPdf(inputStream, waterMarkText, fontPath, outputStream);
        log.info("&#x8F6C;&#x6362;&#x7ED3;&#x675F;&#xFF0C;&#x8017;&#x65F6;&#xFF1A;{}ms",System.currentTimeMillis()-startTime);
    }
}

1.5、注意事项

  1. 页面中不能出现html的特殊字符标记,如 等(代码中已经处理,所有都替换为空)可忽略
    Html转换PDF(Java实用版)
  2. 页面中的标签要符合规范,必须都具有结束标签等

展示:

HTML

Html转换PDF(Java实用版)

PDF

Html转换PDF(Java实用版)

2、基于WKHtmlToPdf

wkhtmltopdf是一个用webkit网页渲染引擎开发的用来将html转成 pdf的工具,可跟多种脚本语言进行集成来转换文档,有windows、linux等平台版本。

Wkhtmltopdf可直接把浏览器中浏览的网页转换成一个pdf,他是一个把html页面转换成pdf的软件(需要安装在服务器上)。使用时可通过java代码调用cmd指令完成网页转换为pdf的功能。

下载wkhtmltopdf官网地址:https://wkhtmltopdf.org/downloads.html

蓝奏云地址:https://aerfazhe.lanzouw.com/b01pc4uib
密码:h01i

2.1、安装

2.1.1、Windows

Html转换PDF(Java实用版)

功能测试:

在安装目录 bin 执行如下命令生成 PDF

wkhtmltopdf.exe https://www.baidu.com/ C:\Users\wk\Desktop\1\1.pdf

Html转换PDF(Java实用版)

Html转换PDF(Java实用版)

效果图:

Html转换PDF(Java实用版)

为了方便使用:可自行配置全局环境变量哈

注意事项:

如果是转换本地HTML页面,可能会出现图片禁止访问类型的错误,可加上以下命令进行转换,这是因为wkhtmltopdf升级版本之后默认禁止了访问

&#x5141;&#x8BB8;&#x8BBF;&#x95EE;
--enable-local-file-access

整合后命令:

wkhtmltopdf.exe --enable-local-file-access D:\1.html C:\Users\wk\Desktop\1\1.pdf

2.1.2、Linux

安装

 -ivh &#x5B89;&#x88C5;
rpm -ivh wkhtmltox-0.12.6-1.centos7.x86_64.rpm

配置环境变量

vim /etc/profile

在最后一行加 export PATH=$DIR/wkhtmltox/bin:$PATH 保存退出、

Html转换PDF(Java实用版)
&#x5237;&#x65B0;&#x73AF;&#x5883;
source /etc/profile

功能测试

运行 wkhtmltopdf

报:以下错误

报wkhtmltopdf: error while loading shared libraries: libXrender.so.1: cannot open shared object file: No such file or directory这个错,请运行 apt-get/yum install libXrender*

运行 wkhtmltopdf 报wkhtmltopdf: error while loading shared libraries: libfontconfig.so.1: cannot open shared object file: No such file or directory这个错,请运行apt-get/yum install libfontconfig*

运行 wkhtmltopdf 报wkhtmltopdf: error while loading shared libraries: libXext.so.6: cannot open shared object file: No such file or directory这个错,请运行 apt-get/yum install libXext*

Html转换PDF(Java实用版)

总的来说就是缺少依赖,下载安装依赖

yum install xorg-x11-fonts-75dpi.noarch -g

yum install xorg-x11-fonts-Type1.noarch -g

yum install icu.x86_64 -g

yum install libjpeg -g

yum install libpng -g

优点:

支持中文、图片、CSS等

缺点:

有时对于html文件的转化可能比较慢,对于url的转化速度较快。存在失真情况

2.2、代码实现

2.2.1、wkhtmltopdf工具安装bin地址

wkhtmltopdf工具安装bin地址

public class Consts {

    /**
     * 0.12.6&#x7248;&#x672C;&#x9ED8;&#x8BA4;&#x7981;&#x7528;&#x672C;&#x5730;&#x6587;&#x4EF6;&#x8BBF;&#x95EE;&#xFF08;&#x56FE;&#x7247;&#x7B49;&#xFF09;
     * cmd &#x547D;&#x4EE4; &#x52A0;&#x4E0A;&#x4EE5;&#x4E0B;&#x547D;&#x4EE4;&#x53C2;&#x6570;&#x5373;&#x53EF;
     * &#x8868;&#x793A;&#x542F;&#x52A8;&#x672C;&#x5730;&#x6587;&#x4EF6;&#x8BBF;&#x95EE;
     */
    private final static String PARAMETER = "--enable-local-file-access";

    /**
     * &#x5141;&#x8BB8;&#x672C;&#x5730;&#x6587;&#x4EF6;&#x8BBF;&#x95EE;
     */
    private final static String ALLOW = "--allow";

    /**
     * wkhtmltopdf&#x5728;&#x7CFB;&#x7EDF;&#x4E2D;&#x7684;&#x8DEF;&#x5F84;(&#x5168;&#x8DEF;&#x5F84;)
     */
    public final static String CONVERSION_PLUGSTOOL_PATH_WINDOW = "D:/Software/Software-1/JAVA/wkhtmltopdf/bin/wkhtmltopdf.exe "+PARAMETER;

    /**
     * wkhtmltopdf&#x5728;Linux&#x7CFB;&#x7EDF;&#x4E2D;&#x7684;&#x8DEF;&#x5F84;
     */
    public final static String CONVERSION_PLUGSTOOL_PATH_LINUX = " "+PARAMETER;

}

2.2.2、转换工具类

转换工具类

/**
 * wkhtmltopdf &#x8F6C;&#x6362;&#x5DE5;&#x5177;&#x7C7B;
 */
@Slf4j
public class HtmlToPdfUtil {

    /**
     * wkhtmltopdf&#x5728;&#x7CFB;&#x7EDF;&#x4E2D;&#x7684;&#x8DEF;&#x5F84;
     */
    private static String toPdfTool = Consts.CONVERSION_PLUGSTOOL_PATH_WINDOW;

    /**
     * html&#x8F6C;pdf
     *
     * @param srcPath  html&#x8DEF;&#x5F84;&#xFF0C;&#x53EF;&#x4EE5;&#x662F;&#x786C;&#x76D8;&#x4E0A;&#x7684;&#x8DEF;&#x5F84;&#xFF0C;&#x4E5F;&#x53EF;&#x4EE5;&#x662F;&#x7F51;&#x7EDC;&#x8DEF;&#x5F84;
     * @param destPath pdf&#x4FDD;&#x5B58;&#x8DEF;&#x5F84;
     * @return &#x8F6C;&#x6362;&#x6210;&#x529F;&#x8FD4;&#x56DE;true
     */
    public static boolean convert(String srcPath, String destPath) {

        log.info("convert.req srcPath={} ,destPath={}",srcPath,destPath);
        File file = new File(destPath);
        File parent = file.getParentFile();
        // &#x5982;&#x679C;pdf&#x4FDD;&#x5B58;&#x8DEF;&#x5F84;&#x4E0D;&#x5B58;&#x5728;&#xFF0C;&#x5219;&#x521B;&#x5EFA;&#x8DEF;&#x5F84;
        if (!parent.exists()) {
            parent.mkdirs();
        }
        StringBuilder cmd = new StringBuilder();
        String property = System.getProperty("os.name");
        log.info("&#x5F53;&#x524D;&#x8FD0;&#x884C;&#x7CFB;&#x7EDF;&#xFF1A;{}",property);
        if (property.indexOf("Windows") == -1) {
            // &#x975E;windows &#x7CFB;&#x7EDF;
            toPdfTool = Consts.CONVERSION_PLUGSTOOL_PATH_LINUX;
        }
        cmd.append(toPdfTool);
        cmd.append(" ");
        cmd.append(" \"");
        cmd.append(srcPath);
        cmd.append("\" ");
        cmd.append(" ");
        cmd.append(destPath);

        System.out.println(cmd.toString());
        boolean result = true;
        try {
            //            &#x6253;&#x5F00;&#x7CFB;&#x7EDF;&#x547D;&#x4EE4;
            Process proc = Runtime.getRuntime().exec(cmd.toString());
            HtmlToPdfInterceptor error = new HtmlToPdfInterceptor(proc.getErrorStream());
            HtmlToPdfInterceptor output = new HtmlToPdfInterceptor(proc.getInputStream());
            error.start();
            output.start();
            proc.waitFor();
        } catch (Exception e) {
            result = false;
            e.printStackTrace();
        }

        return result;
    }

    public static void main(String[] args) {
        long startTime = System.currentTimeMillis();
        log.info("generate pdf start ... ");
        // &#x6E90;HTML&#x9875;&#x9762;&#x5730;&#x5740;&#x6216;&#x8DEF;&#x5F84;
        String srcPath = "src/main/resources/html/index2.html";
        // pdf&#x6587;&#x6863;&#x5B58;&#x50A8;&#x8DEF;&#x5F84;
        String destPath = "src/main/resources/x5.pdf";
        HtmlToPdfUtil.convert(srcPath, destPath);
        log.info("Time-consuming to generate pdf time(ms)={}",System.currentTimeMillis()-startTime);
    }
}

2.2.3、开启线程执行

线程执行类

/**
 * &#x7EBF;&#x7A0B;&#x6267;&#x884C;
 */
public class HtmlToPdfInterceptor extends Thread {

    private InputStream is;

    protected HtmlToPdfInterceptor(InputStream is){
        this.is = is;
    }

    @Override
    public void run(){
        try{
            InputStreamReader isr = new InputStreamReader(is, StandardCharsets.UTF_8);
            BufferedReader br = new BufferedReader(isr);
            String line ;
            while ((line = br.readLine()) != null) {
                System.out.println(line); //&#x8F93;&#x51FA;&#x5185;&#x5BB9;
            }
        }catch (IOException e){
            e.printStackTrace();
        }
    }
}

3、Spire.Doc系列(扩展)

将文档从一种格式转换为另一种格式是Spire.Doc的主要功能之一。这种转换只不过是加载和保存操作的组合。因此,使用Spire.DOC可以将文档从任何受支持的加载格式转换为任何受支持的保存格式。

注意:spire.doc分为商业版和免费版,免费版只支持转换前3页,本次示例采用免费版演示

3.1、pom.xml引入Maven仓库路径和依赖

Maven仓库路径

<repositories>
    <repository>
        <id>com.e-iceblue</id>
        <url>http://repo.e-iceblue.cn/repository/maven-public/</url>
    </repository>
</repositories>

引入依赖

<!--    免费版,只支持前三页转化 -->
<dependency>
    <groupid>e-iceblue</groupid>
    <artifactid>spire.doc.free</artifactid>
    <version>3.9.0</version>
</dependency>

3.2、转换工具类

spire转换工具类

/**
 * @Author&#xFF1A;wk
 * @Create&#xFF1A;2022/4/19/18:04
 * @Description&#xFF1A;html&#x8F6C;&#x6362;pdf
 * @Version&#xFF1A;1.0
 */
public class Html3Pdf {

    public static void main(String[] args) throws IOException {

    }

    /**
     * &#x514D;&#x8D39;&#x7248;&#xFF0C;&#x53EA;&#x652F;&#x6301;&#x524D;&#x4E09;&#x9875;&#x8F6C;&#x6362;
     * @param inputHtml HTML&#x5730;&#x5740;
     * @param pdfName pdf&#x4FDD;&#x5B58;&#x5730;&#x5740;
     * @throws IOException
     */
    public void  spireDoc(String inputHtml,String pdfName) throws IOException {
        inputHtml = "src/main/resources/html/index2.html";
        //&#x65B0;&#x5EFA;Document&#x5BF9;&#x8C61;
        Document doc = new Document();
        //&#x6DFB;&#x52A0;section
        Section sec = doc.addSection();

//        &#x5C06;html&#x8F6C;&#x5316;&#x4E3A;&#x6D41;&#x5B57;&#x7B26;&#x4E32;
        String htmlText = readTextFromFile(inputHtml);
        //&#x6DFB;&#x52A0;&#x6BB5;&#x843D;&#x5E76;&#x5199;&#x5165;HTML&#x6587;&#x672C;
        sec.addParagraph().appendHTML(htmlText);
        pdfName = "src/main/resources/x4.pdf";
        //&#x5C06;&#x6587;&#x6863;&#x53E6;&#x5B58;&#x4E3A;PDF
        doc.saveToFile(pdfName, FileFormat.PDF);
        doc.dispose();
    }

    /**
     * &#x5C06;&#x8BE5;&#x8DEF;&#x5F84;&#x7684;HTML&#x9875;&#x9762;&#x8F6C;&#x5316;&#x4E3A;&#x6D41;&#x5B57;&#x7B26;&#x4E32;
     * @param fileName &#x6587;&#x4EF6;&#x5730;&#x5740;
     * @return
     * @throws IOException
     */
    public static String readTextFromFile(String fileName) throws IOException {
        StringBuffer sb = new StringBuffer();
        BufferedReader br = new BufferedReader(new FileReader(fileName));
        String content;
        while ((content = br.readLine()) != null) {
            sb.append(content);
        }
        return sb.toString();
    }
}

至此就完结啦,可自行根据需求进行选择哦,测试效果和上面截图一样,此处就不进行展示啦

Original: https://www.cnblogs.com/aerfazhe/p/16170095.html
Author: 阿尔法哲
Title: Html转换PDF(Java实用版)

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/620207/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球