Flying HTML生成PDF添加水印

2024-01-13 04:20

本文主要是介绍Flying HTML生成PDF添加水印,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

HTML转PDF并添加水印

<!-- 用于生成PDF -->
<dependency><groupId>org.xhtmlrenderer</groupId><artifactId>flying-saucer-pdf</artifactId><version>9.1.20</version>
</dependency>import java.io.File;
import java.io.FileOutputStream;
import java.util.Random;
import org.xhtmlrenderer.pdf.ITextRenderer;
import com.lowagie.text.Element;
import com.lowagie.text.Font;
import com.lowagie.text.Image;
import com.lowagie.text.Phrase;
import com.lowagie.text.Rectangle;
import com.lowagie.text.pdf.BaseFont;
import com.lowagie.text.pdf.ColumnText;
import com.lowagie.text.pdf.PdfContentByte;
import com.lowagie.text.pdf.PdfGState;
import com.lowagie.text.pdf.PdfReader;
import com.lowagie.text.pdf.PdfStamper;public class HtmlToPdfConverter {public static void main(String[] args) throws Exception {String htmlContent = "<html><head><style>body { font-family: 'SimHei', sans-serif; }</style></head><body><h1>我的标题</h1><p>测试pdf</p></body></html>";// 使用Flying Saucer渲染HTML到临时PDF文件File tempFile = File.createTempFile("temp", ".pdf");ITextRenderer renderer = new ITextRenderer();//设置字体File fontFile = new File("F:\\weixin\\emlsr\\src\\main\\resources\\font\\simhei.ttf");BaseFont baseFont = BaseFont.createFont(fontFile.getAbsolutePath(), BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED);renderer.getFontResolver().addFont(fontFile.getAbsolutePath(), baseFont.getEncoding(), BaseFont.NOT_EMBEDDED);//生成数据renderer.setDocumentFromString(htmlContent);renderer.layout();renderer.createPDF(new FileOutputStream(tempFile));// 用iText打开临时PDF文件,并添加水印PdfGState gs = new PdfGState();gs.setFillOpacity(0.5f); // 设置为 50% 的透明度Font font = new Font(baseFont, 30, Font.NORMAL);PdfReader reader = new PdfReader(tempFile.getAbsolutePath());PdfStamper stamper = new PdfStamper(reader, new FileOutputStream("c:\\output.pdf"));//水印图片(001)//Image watermarkImage = Image.getInstance("C:\\1.jpg");//float scale = 0.2f; // 水印图片缩放比例//watermarkImage.scaleAbsolute(watermarkImage.getWidth() * scale, watermarkImage.getHeight() * scale);//水印平铺(002)// 获取一个页面尺寸作为参考来计算水印图片的缩放比例//Image watermarkImage = Image.getInstance("C:\\1.jpg");// 设置水印图片平铺的宽度和高度(例如:将水印图片设为100x100像素)//float tileWidth = 100f;//float tileHeight = 100f;//watermarkImage.scaleAbsolute(tileWidth, tileHeight);//水印随机平铺3个(003)Image watermarkImage = Image.getInstance("C:\\1.jpg");// 设置水印图片平铺的宽度和高度(例如:将水印图片设为100x100像素)float tileWidth = 100f;float tileHeight = 100f;Random random = new Random(); // 创建一个随机数生成器int n = reader.getNumberOfPages();for (int i = 1; i <= n; i++) {PdfContentByte underContent = stamper.getUnderContent(i);underContent.setGState(gs);// 字体添加透明度ColumnText.showTextAligned(underContent, Element.ALIGN_CENTER,new Phrase("水印文字",font),reader.getPageSize(i).getWidth() / 2,reader.getPageSize(i).getHeight() / 2,45); // 角度可调整水印倾斜程度// 获取页面尺寸并计算水印位置(001)//Rectangle pageRect = reader.getPageSizeWithRotation(i);//float x = (pageRect.getWidth() - watermarkImage.getScaledWidth()) / 2;//float y = (pageRect.getHeight() - watermarkImage.getScaledHeight()) / 2;// 添加水印图片//underContent.addImage(watermarkImage, watermarkImage.getWidth(), 0, 0, watermarkImage.getHeight(), x, y);//水印平铺(002)满屏//Rectangle pageRect = reader.getPageSizeWithRotation(i);// 计算并添加水印图片的位置(按照平铺效果)//for (float x = 0; x < pageRect.getWidth(); x += tileWidth) {//    for (float y = 0; y < pageRect.getHeight(); y += tileHeight) {//        underContent.addImage(watermarkImage, tileWidth, 0, 0, tileHeight, x, y);//    }//}//(003)Rectangle pageRect = reader.getPageSizeWithRotation(i);// 计算并添加三个随机位置的水印图片for (int j = 0; j < 3; j++) {// 随机计算X和Y坐标float x = random.nextFloat() * (pageRect.getWidth() - tileWidth);float y = random.nextFloat() * (pageRect.getHeight() - tileHeight);underContent.addImage(watermarkImage, tileWidth, 0, 0, tileHeight, x, y);}}// 关闭stamper.close();reader.close();tempFile.delete();System.out.println("带有水印的PDF文件已生成至: output.pdf");}
}

这篇关于Flying HTML生成PDF添加水印的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/600233

相关文章

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框

HTML img标签和超链接标签详细介绍

《HTMLimg标签和超链接标签详细介绍》:本文主要介绍了HTML中img标签的使用,包括src属性(指定图片路径)、相对/绝对路径区别、alt替代文本、title提示、宽高控制及边框设置等,详细内容请阅读本文,希望能对你有所帮助... 目录img 标签src 属性alt 属性title 属性width/h

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.

HTML5 中的<button>标签用法和特征

《HTML5中的<button>标签用法和特征》在HTML5中,button标签用于定义一个可点击的按钮,它是创建交互式网页的重要元素之一,本文将深入解析HTML5中的button标签,详细介绍其属... 目录引言<button> 标签的基本用法<button> 标签的属性typevaluedisabled

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,

Python中图片与PDF识别文本(OCR)的全面指南

《Python中图片与PDF识别文本(OCR)的全面指南》在数据爆炸时代,80%的企业数据以非结构化形式存在,其中PDF和图像是最主要的载体,本文将深入探索Python中OCR技术如何将这些数字纸张转... 目录一、OCR技术核心原理二、python图像识别四大工具库1. Pytesseract - 经典O

CSS place-items: center解析与用法详解

《CSSplace-items:center解析与用法详解》place-items:center;是一个强大的CSS简写属性,用于同时控制网格(Grid)和弹性盒(Flexbox)... place-items: center; 是一个强大的 css 简写属性,用于同时控制 网格(Grid) 和 弹性盒(F