站長資訊網
最全最豐富的資訊網站

示例小程序生成海報(java后端)

示例小程序生成海報(java后端)

【相關學習推薦:小程序開發教程】

實現方案

前端人員,提供相關的html頁面, 后端人員提供接口,前端人員通過參數設置html頁面需要渲染的內容, 最后使用wkhtmltoimage或者phantomjs 對html 進行截圖生成海報, 個人感覺wkhtmltoiamge 比phantomjs 要快一點,穩定一點我主要說下wkhtmltoimage的實現方案

實現步驟

安裝環境

官網地址:https://wkhtmltopdf.org/

windows: 下載安裝包安裝即可

linux: 下載對應的安裝包 ,還需安裝對應中文字體(phantomjs 也需要安裝字體),html中需要聲明引用

yum install libjpeg libXrender libXext xorg-x11-fonts-75dpi.noarch xorg-x11-fonts-Type1 bitmap-fonts-cjk

rpm -ivh wkhtmltox-0.12.6-1.centos7.x86_64.rpm

安裝字體

yum install bitmap-fonts-cjk

mkdir /usr/share/fonts/win

拷貝字體到 /usr/share/fonts/win下

cd /usr/share/fonts/win
mkfontscale
mkfontdir
fc-cache

相關代碼

利用java 執行命令 調用wkhtmltoImage 設置相關參數,具體參數查看wkhtmltoImage 命令提示

package com.yumingzhu.wxweb.util;  import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader;  /**  * @Description   * @Author yumigzhu  * @Date 2020/7/22 20:12  */  public class CustomWKHtmlToPdfUtil { 	private static String tempPath = "C:/apps/tmpFile";// 圖片保存目錄  	public static String getCommand(String htmlToImage, String sourceFilePath, String targetFilePath) { 		//--quality 設置為50 是比較合適的, 默認的94 可能會導致圖片文件過大 		ProcessBuilder pb = new ProcessBuilder(htmlToImage, "--crop-w", "800", "--width", "800","--quality", "50", 				sourceFilePath, targetFilePath); 		Process process; 		try { 			process = pb.start(); 			//注意,調用process.getErrorStream()而不是process.getInputStream() 			BufferedReader errStreamReader = new BufferedReader(new InputStreamReader(process.getErrorStream())); 			System.out.println("read errstreamreader"); 			String line = null; 			line = errStreamReader.readLine(); 			while (line != null) { 				System.out.println(line); 				line = errStreamReader.readLine(); 			} 			process.destroy(); 			System.out.println("destroyed process"); 		} catch (IOException e) { 			e.printStackTrace(); 		} 		return targetFilePath; 	}  	public static void main(String[] args) throws Exception { 		String imagePath = tempPath + "/" + System.currentTimeMillis() + ".png";//圖片路徑 		System.out.println(imagePath); 		String htmlToImage = "E:\softwareAPP\wkhtmltopdf\bin\wkhtmltoimage.exe";  		CustomWKHtmlToPdfUtil.getCommand(htmlToImage, 				"file:///G:/share/text_none_title_share/index.html", 				imagePath);  		System.out.println("執行完成"); 	} }

踩坑記錄

  • 如果html頁面設置的寬高比較小, 這樣截出來的圖片也會比較小,比較模糊,, 增大html 的寬高,可以使圖片更清晰,這樣會導致截出來的圖片文件更大,這樣用戶在小程序下載過程會更慢,這里需要自己權衡

  • wkhtmlImage 對 css3 linear-gradient 不支持,不能使用樣式下劃線,可以考慮使用圖片代替

  • 中文字體需要聲明引用,才能生效

相關學習推薦:java基礎教程

贊(0)
分享到: 更多 (0)
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
国产亚洲精品bv在线观看| 99热这就是里面只有精品| 日韩精品无码AV成人观看| 精品久久国产视频| 亚洲精品9999久久久久无码| 亚洲精品欧洲精品| 99久久精品免费精品国产| 亚洲av永久无码精品网站| 国产美女精品一区二区三区| 9丨精品国产高清自在线看| heyzo高无码国产精品| 天天爽夜夜爽夜夜爽精品视频| 人妻无码久久精品人妻| 精品无码一区二区三区电影| 久久精品人人做人人爽电影蜜月| 久99久精品免费视频热77 | 久久6这里只有精品| 91精品国产高清| 久久影院综合精品| 日韩精品乱码AV一区二区| 国产AV无码专区亚洲精品| 国产精品熟女高潮视频| 久久久91精品国产一区二区三区| 中文字幕在线精品视频入口一区| 伊人久久综合精品无码AV专区| 91精品啪在线观看国产| 国内精品久久久久久久影视麻豆| 91麻豆精品国产自产在线观看亚洲| 久久九九久精品国产免费直播| 精品久久综合1区2区3区激情| 精品成人一区二区三区四区| 国产精品无码久久久久| 精品无码国产污污污免费网站国产| 久久精品国产一区二区三区不卡| 久久久久久一区国产精品| 国产亚洲精品成人a v小说| 在线观看国产精品普通话对白精品| 国内午夜国产精品小视频| 久久se精品一区二区| 久久中文字幕2021精品| 99精品视频在线观看免费专区|