后端服务HTML转图片实现方案

👽个人博客:https://everspring.github.io/
👽公众号:爱历史的IT男

后端(开发语言JAVA、Python等)实现HTML转图片有三大思路,一、通过第三方JAR包实现,二、借助工具的CLI实现。

 

我们项目中前端 图形是Echarts实现,页面中有很多CSS3语法,用的html2java、cssbox、wkhtmltox导出来的图片都有问题。另外用selenium+webdriver的方式也遇到很多问题,在windows上运行一切正常,但到了Linux上就有问题,最终采用的linux上安装chrome,通过chrome的截屏方式解决。

Chrome CLI生成图片

  • 1、服务器上安装google chrome,也可以安装chromium(chromium是开源的,在Linux epel也有,推荐使用)
yum install -y google-chrome-stable_current_x86_64-88.0.4324.192.rpm
  • 2、安装中文字体
yum -y groupinstall Fonts
  • 3、运行Chrome CLI命令

chrome命令参数见:List of Chromium Command Line Switches « Peter Beverloo

页面可以是一个url,也可以是本地静态的html文件。chrome命令很强大,除了 导出图片,还支持pdf等其他文本格式

有了命令行,代码就可以根据调用命令行方式实行,比如java的

Runtime.getRuntime().exec("google --version", null, dir)
chromium-browser --no-sandbox --headless --disable-gpu --screenshot=test.png -run-all-compositor-stages-before-draw --window-size=1280,1400 woniu.html
或者
google-chrome-stable --no-sandbox --headless --disable-gpu --screenshot=test.png -run-all-compositor-stages-before-draw --window-size=1280,1400 woniu.html

Linux Selenium常见问题:

1、error while loading shared libraries: libxcb.so.1

find / -name "*libxcb.so.1*"
yum install libxcb  # 没有找到自己安装
vim /etc/ld.so.conf # 有找到
/usr/lib  # 在最后一行添加动态库文件所在目录
ldconfig  # 刷新缓存

2、Requires: libc.so.6(GLIBC_2.xx) 缺少GLIBC_2.xx问题

wget http://ftp.gnu.org/gnu/glibc/glibc-2.xx.tar.gz
tar xf glibc-2.18.tar.gz
cd glibc-2.18
mkdir build
cd build
../configure -prefix=/root/glibc-2.18 -disable-profile -enable-add-ons -with-headers=/usr/include -with-binutils=/usr/bin
make
make install

3、no acceptable C compiler found in $PATH

$ yum install gcc

4、WebDriverException: unknown error: cannot find Chrome binary 两种解决方法:1)自己指定位置;2)放到chromedriver放到/usr/bin(见ChromeDriver · SeleniumHQ/selenium Wiki · GitHub)

ChromeOptions chromeOptions = new ChromeOptions();
chromeOptions.setBinary(new File("/data/renewal/chromedriver"));

5、DevToolsActivePort file doesn't exist Linux的chrome默认不能用root启动,如果需要指定--no-sandbox参数。但可惜的是我的一直不成功。

chromeOptions.addArguments("--no-sandbox");
  • 4
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
实现页面换成 PDF 并导出的最好方案,主要有两种方法:前端实现后端实现。 前端实现: 在前端实现页面换成 PDF 并导出,可以使用 jsPDF 和 html2canvas 库。jsPDF 是一个用于生成 PDF 文件的 JavaScript 库,而 html2canvas 是一个用于将 HTML 元素换为 Canvas 的 JavaScript 库。 以下是一个简单的例子,展示如何在 Vue 中使用 jsPDF 和 html2canvas 实现页面换成 PDF 并导出: 1. 安装 jsPDF 和 html2canvas 库: ```bash npm install jspdf html2canvas --save ``` 2. 在 Vue 组件中引入 jsPDF 和 html2canvas 库: ```javascript import jsPDF from 'jspdf' import html2canvas from 'html2canvas' ``` 3. 在 Vue 组件中定义导出 PDF 的方法: ```javascript export default { methods: { exportPDF() { // 获取需要导出的元素 let element = document.getElementById('pdf-content') // 将元素换为 Canvas html2canvas(element).then(canvas => { // 获取 Canvas 图片数据 let imgData = canvas.toDataURL('image/png') // 计算 PDF 页面大小 let pageWidth = 210 let pageHeight = canvas.height * pageWidth / canvas.width // 创建 PDF 对象 let pdf = new jsPDF('p', 'mm', 'a4') // 添加 PDF 页面 pdf.addImage(imgData, 'PNG', 0, 0, pageWidth, pageHeight) // 导出 PDF 文件 pdf.save('export.pdf') }) } } } ``` 在以上代码中,`exportPDF` 方法用于导出 PDF 文件。首先,通过 `document.getElementById` 获取需要导出的元素,这里假设元素的 ID 为 `pdf-content`。然后,使用 `html2canvas` 将元素换为 Canvas,再通过 Canvas 的 `toDataURL` 方法获取图片数据。接着,计算 PDF 页面大小,创建 jsPDF 对象,并将图片添加到 PDF 中。最后,使用 `pdf.save` 方法导出 PDF 文件。 后端实现: 在后端实现页面换成 PDF 并导出,可以使用一些开源的 PDF 库,比如 wkhtmltopdf、WeasyPrint、PDFKit 等。 其中,wkhtmltopdf 是一个开源的 HTML 到 PDF 换器,可以在 Linux、Windows 和 macOS 等操作系统上使用。WeasyPrint 是一个开源的 HTML 和 CSS 到 PDF 换器,支持 Linux、macOS 和 Windows 等操作系统。PDFKit 是一个 Node.js 库,可以用于生成 PDF 文件。 以下是一个简单的例子,展示如何在 Vue 中使用 wkhtmltopdf 实现页面换成 PDF 并导出: 1. 安装 wkhtmltopdf: ```bash sudo apt-get install wkhtmltopdf ``` 2. 在 Vue 组件中定义导出 PDF 的方法: ```javascript export default { methods: { exportPDF() { // 计算 PDF 文件名 let filename = 'export.pdf' // 获取当前页面 URL let url = window.location.href // 发送 GET 请求,生成 PDF 文件 axios.get(`/api/pdf?url=${encodeURIComponent(url)}&filename=${encodeURIComponent(filename)}`, { responseType: 'blob' }).then(response => { // 创建 blob 对象 let blob = new Blob([response.data], { type: 'application/pdf' }) // 创建下载链接 let link = document.createElement('a') link.href = URL.createObjectURL(blob) link.download = filename // 触发下载 link.click() }) } } } ``` 在以上代码中,`exportPDF` 方法用于导出 PDF 文件。首先,计算 PDF 文件名,这里假设文件名为 `export.pdf`。然后,获取当前页面 URL,将 URL 和文件名作为参数,发送 GET 请求到后端 API,生成 PDF 文件。最后,将返回的二进制数据换为 blob 对象,创建下载链接,并触发下载。 你可以根据需要选择前端实现后端实现,以满足你的需求。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值