首页 >pdf操作 > 内容

openhtmltopdf 简单使用

2023年5月18日 23:05

写这篇文章 主要是整个百度找不到一篇使用openhtmltopdf的文章 没有一个演示项目,github上面只有简单的演示,看不出效果。

openhtmltopdf 是 html片段转pdf文件的一个开源框架 源码在github上,地址是https://github.com/danfickle/openhtmltopdf

目前html片段 不支持js,支持图片、部分css3样式、部分h5样式。下面演示简单用法。

1.pom.xml引入

<dependency>    <!-- ALWAYS required. -->    <groupId>com.openhtmltopdf</groupId>    <artifactId>openhtmltopdf-core</artifactId>    <version>${openhtml.version}</version></dependency><dependency>    <!-- Required for PDF output. -->    <groupId>com.openhtmltopdf</groupId>    <artifactId>openhtmltopdf-pdfbox</artifactId>    <version>${openhtml.version}</version></dependency><dependency>    <!-- Required for image output only. -->    <groupId>com.openhtmltopdf</groupId>    <artifactId>openhtmltopdf-java2d</artifactId>    <version>${openhtml.version}</version></dependency><dependency>    <!-- Optional, leave out if you do not need right-to-left or bi-directional text support. -->    <groupId>com.openhtmltopdf</groupId>    <artifactId>openhtmltopdf-rtl-support</artifactId>    <version>${openhtml.version}</version></dependency><dependency>    <!-- Optional, leave out if you do not need HTML5 parsing support. -->    <groupId>com.openhtmltopdf</groupId>    <artifactId>openhtmltopdf-jsoup-dom-converter</artifactId>    <version>${openhtml.version}</version></dependency><dependency>    <!-- Optional, leave out if you do not need logging via slf4j. -->    <groupId>com.openhtmltopdf</groupId>    <artifactId>openhtmltopdf-slf4j</artifactId>    <version>${openhtml.version}</version></dependency><dependency>    <!-- Optional, leave out if you do not need logging via log4j. -->    <groupId>com.openhtmltopdf</groupId>    <artifactId>openhtmltopdf-log4j</artifactId>    <version>${openhtml.version}</version></dependency><dependency>    <!-- Optional, leave out if you do not need SVG support. -->    <groupId>com.openhtmltopdf</groupId>    <artifactId>openhtmltopdf-svg-support</artifactId>    <version>${openhtml.version}</version></dependency><dependency>    <!-- Optional, leave out if you do not need MathML support. -->    <!-- Introduced in RC-13. -->    <groupId>com.openhtmltopdf</groupId>    <artifactId>openhtmltopdf-mathml-support</artifactId>    <version>${openhtml.version}</version></dependency>

2.代码简单使用

public class OpenHtmlToPDF {    public static void main(String[] args) {        try (OutputStream os = new FileOutputStream("F://pdf//pdfbox//out3.pdf")) { // 输出的pdf            PdfRendererBuilder builder = new PdfRendererBuilder();            builder.useFastMode();            //下面这个方法是要自己指定 字体文件   不然转出的pdf文件中 中文会变成####            builder.useFont(new FSSupplier<InputStream>() {                @Override                public InputStream supply() {                    try {                       //指定 字体文件                        return new FileInputStream("F://pdf//pdfbox//simhei.ttf");                    } catch (FileNotFoundException e) {                        e.printStackTrace();                    }                    return null;                }            }, "simhei", 400, BaseRendererBuilder.FontStyle.NORMAL, true); //第二个参数 一定要和文件名一样!!作用在html页面上              builder.withHtmlContent(readTxt("F://pdf//pdfbox//pdf-css3.html"),                                          Surrogate.Generator.class.getResource("/root.htm").toExternalForm());            //第一个参数是html页面  第二个参数 是一个全空的文件 里面什么都没有 但是后缀一定要是。htm  作用类似于一个画板 如果不添加这个参数或者置为null 则html文件中的图片 不会转化 所以一定需要加             builder.toStream(os);            builder.run();        } catch (FileNotFoundException e) {            e.printStackTrace();        } catch (IOException e) {            e.printStackTrace();        } catch (Exception e) {            e.printStackTrace();        }    }

}

3.html页面注意事项

1.关于字体 。

如果自己指定字体文件,那么要在html页面上 加入

<style>
* {
font-family: 'simhei'; //value是指定字体时 第二个参数
}
</style>

2.标签一定要有闭合 不然会解析失败

效果

转出来的pdf


参考文章:https://blog.csdn.net/hgx2014/article/details/88849482

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时候联系我们修改或删除,在此表示感谢。

特别提醒:

1、请用户自行保存原始数据,为确保安全网站使用完即被永久销毁,如何人将无法再次获取。

2、如果上次文件较大或者涉及到复杂运算的数据,可能需要一定的时间,请耐心等待一会。

3、请按照用户协议文明上网,如果发现用户存在恶意行为,包括但不限于发布不合适言论妄图

     获取用户隐私信息等行为,网站将根据掌握的情况对用户进行限制部分行为、永久封号等处罚。

4、如果文件下载失败可能是弹出窗口被浏览器拦截,点击允许弹出即可,一般在网址栏位置设置

5、欢迎将网站推荐给其他人,网站持续更新更多功能敬请期待,收藏网站高效办公不迷路。

      



登录后回复

共有0条评论