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

        示例小程序生成海報(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號
        主站蜘蛛池模板: 99国产精品无码| 国产精品 日韩欧美| 日本精品久久久中文字幕| 亚洲精品偷拍视频免费观看| 欧美精品华人在线| 亚洲国产精品va在线播放| 国产午夜精品一区二区三区小说| 大伊香蕉精品一区视频在线| 亚洲精品tv久久久久久久久久| 91精品国产自产在线观看| 国内精品伊人久久久久AV影院| 亚洲国产精品成人午夜在线观看| 国产精品自在欧美一区| 亚洲第一精品在线视频| 97精品国产福利一区二区三区| 日韩人妻精品一区二区三区视频| 久久青青草原精品国产软件| 亚洲精品欧美综合| 2022国产精品不卡a| 日韩人妻精品一区二区三区视频| 亚洲精品国产va在线观看蜜芽| 国产亚洲精品a在线观看 | 国产精品狼人久久久久影院 | 国产精品乱码一区二区三区| 久久精品国产99国产精偷 | 99久久免费国产精品| 东京热TOKYO综合久久精品| 久久综合精品国产二区无码| 午夜欧美精品久久久久久久| 亚洲午夜福利精品无码| 亚洲国产婷婷综合在线精品| 欧美日韩专区麻豆精品在线| 精品久久久久久久久久中文字幕 | 国产原创精品 正在播放| 国产精品99久久不卡| 91久久精品电影| 国产成人99久久亚洲综合精品| 在线欧美v日韩v国产精品v| jizz国产精品| 精品一区二区三区色花堂| 九九久久精品国产|