wkhtmltopdf生成圖片的實踐教程,包含完整的環境配置、參數解析及多語言調用示例

歡迎來到濤濤聊AI,最近在研究HTML生成卡片的功能,一起學習下吧。

一、工具特性與安裝

wkhtmltoimage是基于WebKit引擎的開源命令行工具,可將HTML網頁轉換為JPG/PNG等圖片格式,支持CSS渲染、JavaScript執行和響應式布局。安裝方式:

# Linux 
wget https://github.com/wkhtmltopdf/packaging/releases/download/0.12.6-1/wkhtmltox_0.12.6-1.bionic_amd64.deb  
sudo dpkg -i wkhtmltox_0.12.6-1.bionic_amd64.deb  # Windows 
下載安裝包后,將安裝路徑(如C:\Program Files\wkhtmltopdf\bin)加入系統PATH變量

二、基礎圖片生成命令

# 生成PNG圖片(默認分辨率)
wkhtmltoimage https://www.baidu.com  output.png  # 調整圖片質量與尺寸 
wkhtmltoimage --quality 85 --width 1200 --height 900 input.html  output.jpg  # 禁用JS提升生成速度 
wkhtmltoimage --disable-javascript page.html  image.png  

三、高級參數配置(完整示例)

wkhtmltoimage \
--format png \          # 輸出格式 
--crop-w 800 \          # 截圖寬度 
--crop-h 600 \          # 截圖高度 
--zoom 1.5 \            # 縮放比例 
--enable-local-file-access \  # 允許加載本地資源 
--no-images \           # 禁用圖片加載 
--user-agent "Mozilla/5.0" \  # 自定義UA 
header.html  body_content.html  footer.html  combined_output.png  

四、編程語言集成示例

PHP生成方案
<?php 
$url = 'https://example.com/report'; 
$outputFile = '/var/www/output/report_'.date('Ymd').'.png';$command = "wkhtmltoimage --quality 90 --log-level none '$url' '$outputFile'";
exec($command, $output, $returnCode);if ($returnCode === 0) {header('Content-Type: image/png');readfile($outputFile);
} else {echo "生成失敗,錯誤碼:$returnCode";
}
Python調用方案
import pdfkit options = {'format': 'png','quality': 100,'width': 1920,'javascript-delay': 2000  # 等待JS執行2秒 
}pdfkit.from_url( 'http://internal-report-system/page?id=123','report_snapshot.png', options=options 
)

五、實際應用場景

  1. 自動化測試驗證:生成網頁改版前后對比圖
  2. 數據報告存檔:定時抓取Dashboard生成時間序列快照
  3. 輿情監控:保存社交媒體頁面證據截圖
  4. 響應式校驗:批量生成不同分辨率設備預覽圖

六、常見問題處理

  1. 中文亂碼:安裝中文字體包(如fonts-wqy-zenhei
  2. 異步加載缺失:使用--javascript-delay 5000參數等待加載
  3. 登錄認證:通過--cookie name value傳遞會話信息
  4. 內存溢出:添加--use-xserver參數啟用X Server渲染

完整參數手冊可通過wkhtmltoimage --help查看,更多實踐案例可參考中的分頁控制與布局優化技巧。生成圖片與PDF的主要區別在于輸出格式參數,其他配置邏輯基本相通。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/75471.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/75471.shtml
英文地址,請注明出處:http://en.pswp.cn/web/75471.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【在Node.js項目中引入TypeScript:提高開發效率及框架選型指南】

一、TypeScript在Node.js中的核心價值 1.1 靜態類型檢測 // 錯誤示例&#xff1a;TypeScript會報錯 function add(a: number, b: string) {return a b }1.2 工具鏈增強 # 安裝必要依賴 npm install --save-dev typescript types/node ts-node tsconfig.json1.3 代碼維護性提…

化工企業數字化轉型:從數據貫通到生態重構的實踐路徑

一、戰略定位&#xff1a;破解行業核心痛點 化工行業面臨生產安全風險高&#xff08;全國危化品企業事故率年增5%&#xff09;、能耗與排放壓力大&#xff08;占工業總能耗12%&#xff09;、供應鏈協同低效&#xff08;庫存周轉率低于制造業均值30%&#xff09;三大挑戰。《石…

C#網絡編程(Socket編程)

文章目錄 0、寫在前面的話1、Socket 介紹1.1 Socket是什么1.2 Socket在網絡中的位置 2、C# 中的Socket參數2.1 超時控制參數2.2 緩沖區參數2.3 UDP專用參數 3、C# 中的Socket API3.1 Socket&#xff08;構造函數&#xff09;3.1.1 SocketType3.1.2 ProtocolType3.1.3 AddressFa…

Docker部署ES集群

引言&#xff1a; Elasticsearch&#xff08;ES&#xff09;作為分布式搜索引擎&#xff0c;其核心價值在于通過集群部署實現高可用性和數據冗余。 本實驗對比兩種典型部署方案&#xff1a; 原生Linux部署&#xff1a;直接安裝ES服務&#xff0c;適用于生產環境&#xff0c;資…

老硬件也能運行的Win11 IoT LTSC (OEM)物聯網版

#記錄工作 Windows 11 IoT Enterprise LTSC 2024 屬于物聯網相關的版本。 Windows 11 IoT Enterprise 是為物聯網設備和場景設計的操作系統版本。它通常針對特定的工業控制、智能設備等物聯網應用進行了優化和定制&#xff0c;以滿足這些領域對穩定性、安全性和長期支持的需求…

【教程】xrdp修改遠程桌面環境為xfce4

轉載請注明出處&#xff1a;小鋒學長生活大爆炸[xfxuezhagn.cn] 如果本文幫助到了你&#xff0c;歡迎[點贊、收藏、關注]哦~ 目錄 xfce4 vs GNOME對比 配置教程 1. 安裝 xfce4 桌面環境 2. 安裝 xrdp 3. 配置 xrdp 使用 xfce4 4. 重啟 xrdp 服務 5. 配置防火墻&#xff…

【數據結構 · 初階】- 順序表

目錄 一、線性表 二、順序表 1.實現動態順序表 SeqList.h SeqList.c Test.c 問題 經驗&#xff1a;free 出問題&#xff0c;2種可能性 解決問題 &#xff08;2&#xff09;尾刪 &#xff08;3&#xff09;頭插&#xff0c;頭刪 &#xff08;4&#xff09;在 pos 位…

windows主機中構建適用于K8S Operator開發環境

基于win 10 打造K8S應用開發環境&#xff08;wsl & kind&#xff09; 一、wsl子系統安裝 1.1 確認windows系統版本 cmd/powershell 或者win r 運行winver 操作系統要> 19044 1.2 開啟wsl功能 控制面板 -> 程序 -> 啟用或關閉Windows功能 開啟適用于Linu…

計算機視覺色彩空間全解析:RGB、HSV與Lab的實戰對比

計算機視覺色彩空間全解析&#xff1a;RGB、HSV與Lab的實戰對比 一、前言二、RGB 色彩空間?2.1 RGB 色彩空間原理?2.1.1 基本概念?2.1.2 顏色混合機制? 2.2 RGB 在計算機視覺中的應用?2.2.1 圖像讀取與顯示?2.2.2 顏色識別?2.2.3 RGB 色彩空間的局限性? 三、HSV 色彩空…

PyTorch多GPU訓練實戰:從零實現到ResNet-18模型

本文將介紹如何在PyTorch中實現多GPU訓練&#xff0c;涵蓋從零開始的手動實現和基于ResNet-18的簡潔實現。代碼完整可直接運行。 1. 環境準備與庫導入 import torch from torch import nn from torch.nn import functional as F from d2l import torch as d2l from torchvisio…

micro介紹

micro介紹 Micro 的首要特點是易于安裝&#xff08;它只是一個靜態的二進制文件&#xff0c;沒有任何依賴關系&#xff09;和易于使用Micro 支持完整的插件系統。插件是用 Lua 編寫的&#xff0c;插件管理器可自動為你下載和安裝插件。使用簡單的 json 格式配置選項&#xff0…

Linux內核分頁——線性地址結構

每個進程通過一個指針&#xff08;即進程的mm_struct→pgd&#xff09;指向其專屬的頁全局目錄&#xff08;PGD&#xff09;&#xff0c;該目錄本身存儲在一個物理頁框中。這個頁框包含一個類型為pgd_t的數組&#xff0c;該類型是與架構相關的數據結構&#xff0c;定義在<as…

微信小程序開發:微信小程序上線發布與后續維護

微信小程序上線發布與后續維護研究 摘要 微信小程序作為移動互聯網的重要組成部分,其上線發布與后續維護是確保其穩定運行和持續優化的關鍵環節。本文從研究學者的角度出發,詳細探討了微信小程序的上線發布流程、后續維護策略以及數據分析與用戶反饋處理的方法。通過結合實…

分享一些使用DeepSeek的實際案例

文章目錄 前言職場辦公領域生活領域學習教育領域商業領域技術開發領域 前言 以下是一些使用 DeepSeek 的實際案例&#xff1a; DeepSeek使用手冊資源鏈接&#xff1a;https://pan.quark.cn/s/fa502d9eaee1 職場辦公領域 行業競品分析&#xff1a;剛入職的小李被領導要求一天內…

flink iceberg寫數據到hdfs,hive同步讀取

目錄 1、組件版本 環境變量配置 2、hadoop配置 hadoop-env.sh core-site.xml hdfs-site.xml mapred-site.xml yarn-site.xml 3、hive配置 hive-env.sh hive-site.xml HIVE LIB 原始JAR 4、flink配置集成HDFS和YARN 修改iceberg源碼 編譯iceberg-flink-runtime-1…

qq郵箱群發程序

1.界面設計 1.1 環境配置 在外部工具位置進行配置 1.2 UI界面設計 1.2.1 進入QT的UI設計界面 在pycharm中按順序點擊&#xff0c;進入UI編輯界面&#xff1a; 點擊第三步后進入QT的UI設計界面&#xff0c;通過點擊按鈕進行界面設計&#xff0c;設計后進行保存到當前Pycharm…

【C++游戲引擎開發】第10篇:AABB/OBB碰撞檢測

一、AABB(軸對齊包圍盒) 1.1 定義 ?最小點: m i n = ( x min , y min , z min ) \mathbf{min} = (x_{\text{min}}, y_{\text{min}}, z_{\text{min}}) min=(xmin?,ymin?,zmin?)?最大點: m a x = ( x max , y max , z max ) \mathbf{max} = (x_{\text{max}}, y_{\text{…

大模型是如何把向量解碼成文字輸出的

hidden state 向量 當我們把一句話輸入模型后&#xff0c;例如 “Hello world”&#xff1a; token IDs: [15496, 995]經過 Embedding Transformer 層后&#xff0c;會得到每個 token 的中間表示&#xff0c;形狀為&#xff1a; hidden_states: (batch_size, seq_len, hidd…

C++指針(三)

個人主頁:PingdiGuo_guo 收錄專欄&#xff1a;C干貨專欄 文章目錄 前言 1.字符指針 1.1字符指針的概念 1.2字符指針的用處 1.3字符指針的操作 1.3.1定義 1.3.2初始化 1.4字符指針使用注意事項 2.數組參數&#xff0c;指針參數 2.1數組參數 2.1.1數組參數的概念 2.1…

生命篇---心肺復蘇、AED除顫儀使用、海姆立克急救法、常見情況急救簡介

生命篇—心肺復蘇、AED除顫儀使用、海姆立克急救法、常見情況急救簡介 文章目錄 生命篇---心肺復蘇、AED除顫儀使用、海姆立克急救法、常見情況急救簡介一、前言二、急救1、心肺復蘇&#xff08;CPR&#xff09;&#xff08;1&#xff09;適用情況&#xff08;2&#xff09;操作…