Java 将PDF转换为PNG图片、HTML、SVG、XPS及Word文件格式
本文将介绍如何使用Java程序来将PDF文档转换为PNG图片、HTML、Word、SVG及XPS格式。
- 工具:Free Spire.PDF for Java(免费版)
- 环境创建:
方法1:首先,通过E-iceblue中文官网下载获取Free Spire.PDF for Java;其次,解压后找到lib文件夹下的Spire.pdf.jar;最后,将jar文件导入Java IEDA中。
方法2:通过maven仓库安装产品及添加相关依赖包。
示例1 将PDF 转换为PNG图片格式
转换效果:
示例2 将 PDF 转换为 HTML、SVG、XPS、Word 格式
转换效果:
(本文完)
Java后端实现HTML网页报表导出pdf方案
项目中经常有生成图表报告的需求。实现的方式有很多,下面几种方案,各有优缺点。
纯java后端实现:后端JFreeChart等绘制库画好图表,再通过itext库导出为pdf。该方案能实现简单的图表功能,样式、格式调整等可能会花大量时间。适合中小型报表开发项目。
前端绘制图表,后端运行时命令调用wkhtmltopdf生成pdf:后端通过运行时命令调用node js,js使用wkhtmltopdf库动态访问报表url地址,HTML内容渲染完成后生成pdf文件。该方案,使用纯前端js绘制图表,能实现复杂需求。但wkhtmltopdf库对不同浏览器的js存在兼容性问题,导出成pdf文件时存在各种坑,在单页面技术支持还不太成熟。适合丰富报表的pdf导出,但兼容性问题维护成本太高。
前端绘制图表,后端运行时命令调用puppeteer生成pdf:后端通过运行时命令调用node js,js使用puppeteer库动态访问报表url地址,HTML内容渲染完成后生成pdf文件。该方案和wkhtmltopdf方案类似,但兼容性更好。puppeteer是 Chrome 开发团队在 2017 年发布的一个 Node.js 包,用来模拟 Chrome 浏览器的运行。可以在面的环境中运行Chrome或通过命令行、程序语言操作 Chrome。理论上Chrome中显示的图表,就能通过该库生成一致的pdf文件内容,不用浪费很多时间在页面样式和兼容性问题上。
本文选择puppeteer方案介绍如何生成一个pdf报表。细心的小伙伴可能注意到了,既然puppeteer是js库,为什么不直接前端导出pdf,干嘛这么麻烦还通过后端绕一圈来实现?
这主要出于需求和用户体验的考虑,有些业务场景需要通过api接口动态生成pdf报表,不需要用户访问界面。如果生成的pdf的报表很大,直接在用户端生成,可能占用大量客户端资源,导致页面崩溃或假死,从而影响使用体验。
1.先安装NodeJs,网上教程很多,本文不再赘述。
2.安装puppeteer依赖,如果npm下载不成功就使用cnpm命令(cnpm需要先安装)
3.在安装puppeteer依赖的目录下创建page2pdf.js
page2pdf.js文件引入puppeteer依赖库,通过传入siteUrl参数访问HTML page页面,page.pdf生成文件,再通过process.stdout.write(pdf)返回java后台。
4.创建java PuppeteerHtmlToPdf.java文件
5.报表生成
page2pdf.js页面目录打开命令行,执行指令。
运行指令,生成pdf
查看对应目录,已动态生成了一个page.pdf文件
打开pdf文件,对应HTML内容已生成。
本文介绍了报表导出pdf的3种方式,通过优缺点分析,详细阐述了puppeteer的实现方式。并通过百度页面的pdf导出做了演示。
希望本文对有类似报表pdf导出需求的小伙伴有所参考和帮助。若存在不足或更好方案,请留言讨论。
和付费网盘说再见,跟着本文自己起个网盘(Java)
项目源码获取:关注转发之后私信回复【源码】即可免费获取到
一款开源、使用简单、功能完整的 Java 网盘/云盘系统。支持在线视频播放、文档在线预览、音乐播放、图片查看等功能的文件云存储平台。
技术栈
- JDK 版本:1.8.0_131
- 项目管理框架:Maven(m2e 1.8.0 for Eclipse)
- Archetype:mavem-archetype-quickstart 1.1
- Spring Boot:SpringBoot 基于 Spring 开发,旨在提高微服务的开发效率。
- MyBatis:一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。
- H2 DB:一款开源的嵌入式数据库引擎,采用 Java 语言编写,不受平台的限制。
2.1.1 下载安装包
直接从官网下载最新的安装包,安装地址:https://kohgylw.gitee.io/
项目比较温馨,支持三种下载方式:Github、阿里云、Gitee 下载。如下图:
2.1.2 检查配置
这里主要检查一下本地 JDK 是否已安装,在命令行窗口执行 java -version 查看 Java 版本。如下所示表示已安装,就可以进行下一步操作。
2.1.3 运行 jar
双击 kiftd-1.0.29-RELEASE.jar,或者在命令行执行 java -jar kiftd-1.0.29-RELEASE.jar 命令都运行可以jar 文件,会弹出安装的界面,如下图:
这个界面的这几个按钮说明一下:
- 开启(Start):运行网盘服务,初次启动的端口默认是 8080。
- 文件(Files):这个按钮菜单中主要有网盘文件导入,导出,删除,刷新功能。
- 设置(Setting):设置功能主要可以设置网盘的服务端口,网盘的物理存储路径等信息。
- 退出(Exit):关闭网盘系统。
点击 开启(Start) 按钮即可运行网盘,这里我设置的端口是 8090,在浏览器访问: localhost:8090,运行效果如下图:
项目是运行了,发现一个问题无法上传文件?因为我们忘了登录这个操作。点击系统 登录按钮,填入账号和密码即可登录。那么登录密码在哪里呢?这里我直接告诉大家,用户信息在 conf/account.properties,文件内容如下:
- 用户名:admin
- 密码:000000
这样登录之后就可以使用网盘的所有功能了。
2.2.1 安装 Screen 工具
Screen 工具能够虚拟出一个终端并执行相应的操作。因为本篇所讲的网盘需要一个终端。执行如下命令安装 Screen:
2.2.2 Screen 常用命令
2.2.3 命令行操作
在 Linux 环境上使用 console 模式启动的效果是这样的:
命令行输入 -start 即可运行项目。例如输入 -files 控制台显示是这样的:
其实和 Windows 上一样,包括文件导入,导出,删除功能,多了几个命令是查看文件,切换目录等功能。
打开 kohgylw.kiftd.mc.MC 类,进行测试运行。注意:本文使用 Eclipse 工具打开。
3.3.1 前台请求
就以创建目录这个功能为例。我们先看前端功能。点击“操作”->“新建文件夹”,填写文件夹名称,点击保存如下图:
我们知道前台 新建文件夹 功能调用的后台接口是 newFolder.ajax
3.3.2 后端接口通过前台请求可知调用的后台接口为 homeController/newFolder.ajax。打开代码实现,我们会看到下面这个方法。
- 点击 操作,可以上传文件和上传文件夹,如下图:
- 将本地需要上传的文件,拖拽网盘页面也可以上传此文件。
- 上传视频到网盘,网盘也支持在线视频播放,效果如下图:
- 上传音频,例如我最喜欢 周杰伦 的歌曲,可以在线播放了。
网盘还对一些常用功能添加了快捷键。功能和快捷键参照如下:
4.4 配置文件修改
配置文件在项目 conf 目录,包括两个配置文件:
- account.properties:配置账号信息,权限信息
- server.properties:服务器的配置文件,可配置服务器端口,缓冲文件大小等
网盘支持文档 txt、pdf、docx、ppt 在线预览功能,支持图片的在线预览。图片预览效果如下:
pdf 文件预览效果如下:
网盘也考虑文件的分享,它可以生成下载链接,浏览器访问下载链接就可以直接下载文件。选择需要下载的文件,点击 下载 按钮,选择 下载链接+,既可以生成文件下载链接。如下图:
教程至此已经结束,你自己的网盘跑起来了吗?网盘是不是还不错?而且搭建也特别简单。一些重要的东西就可以存放到自己的网盘啦!说到底,编程语言只是工具,我们只要很好的使用工具,再加上自己天马行空的思想,我想会创造出更多不可思议的项目。
项目源码获取:关注转发之后私信回复【源码】即可免费获取到
本文作者及来源:Renderbus瑞云渲染农场https://www.renderbus.com
文章为作者独立观点不代本网立场,未经允许不得转载。