itext实现PDF生成的两种方式-从HTML到PDF
maven依赖pom配置:
<dependency> <groupId>com.itextpdf</groupId> <artifactId>itext-asian</artifactId> <version>5.2.0</version> </dependency> <dependency> <groupId>com.itextpdf</groupId> <artifactId>itextpdf</artifactId> <version>5.5.10</version> </dependency> <dependency> <groupId>com.itextpdf.tool</groupId> <artifactId>xmlworker</artifactId> <version>5.5.10</version> </dependency>
(一)第一种生成
private void doGenerateContractPdf(String contractUrl, String serverRealPath, String pdfFileName) throws Exception { com.itextpdf.text.Document document = new com.itextpdf.text.Document(PageSize.LETTER); try { PdfWriter pdfWriter = PdfWriter.getInstance(document, new FileOutputStream(serverRealPath + pdfFileName)); document.open(); String responseString = HttpUtils.httpPostUrlForPdf(contractUrl); XMLWorkerHelper worker = XMLWorkerHelper.getInstance(); worker.parseXHtml(pdfWriter, document, new ByteArrayInputStream(responseString.getBytes()), Charset.forName("UTF-8"), new AsianFontProvider()); } catch (Exception e) { logger.error("==========异常==========",e); throw e; } finally { document.close(); } }
(二)第二种生成 自定义Image类支持BASE64图片生成
private void doGenerateContractPdfForBase64(String contractUrl, String serverRealPath, String pdfFileName) throws Exception {
com.itextpdf.text.Document document = new com.itextpdf.text.Document(PageSize.LETTER); try { PdfWriter pdfWriter = PdfWriter.getInstance(document, new FileOutputStream(serverRealPath + pdfFileName)); document.open(); String responseString = HttpUtils.httpPostUrlForPdf(contractUrl); InputStream in = new ByteArrayInputStream(responseString.getBytes()); com.itextpdf.tool.xml.html.TagProcessorFactory tagProcessorFactory = Tags.getHtmlTagProcessorFactory(); tagProcessorFactory.removeProcessor(HTML.Tag.IMG); tagProcessorFactory.addProcessor(new ImageTagProcessor(), HTML.Tag.IMG); CssFilesImpl cssFiles = new CssFilesImpl(); cssFiles.add(XMLWorkerHelper.getInstance().getDefaultCSS()); StyleAttrCSSResolver cssResolver = new StyleAttrCSSResolver(cssFiles); HtmlPipelineContext hpc = new HtmlPipelineContext(new CssAppliersImpl(new AsianFontProvider())); hpc.setAcceptUnknown(true).autoBookmark(true).setTagFactory(tagProcessorFactory); HtmlPipeline htmlPipeline = new HtmlPipeline(hpc, new PdfWriterPipeline(document, pdfWriter)); CssResolverPipeline pipeline = new CssResolverPipeline(cssResolver, htmlPipeline); XMLWorker worker = new XMLWorker(pipeline, true); Charset charset = Charset.forName("UTF-8"); XMLParser parser = new XMLParser(true, worker, Charset.forName("UTF-8")); if(charset != null) { parser.parse(in, charset); } else { parser.parse(in); } } catch (Exception e) { logger.error("==========异常==========",e); throw e; } finally { document.close(); } }
import java.util.ArrayList; import java.util.List; import java.util.Map; import com.itextpdf.text.Chunk; import com.itextpdf.text.Element; import com.itextpdf.text.Image; import com.itextpdf.text.pdf.codec.Base64; import com.itextpdf.tool.xml.NoCustomContextException; import com.itextpdf.tool.xml.Tag; import com.itextpdf.tool.xml.WorkerContext; import com.itextpdf.tool.xml.exceptions.RuntimeWorkerException; import com.itextpdf.tool.xml.html.HTML; import com.itextpdf.tool.xml.pipeline.html.HtmlPipelineContext; /** * Created by gaozz on 2017/1/17. */ public class ImageTagProcessor extends com.itextpdf.tool.xml.html.Image { /* * (non-Javadoc) * * @see com.itextpdf.tool.xml.TagProcessor#endElement(com.itextpdf.tool.xml.Tag, java.util.List, com.itextpdf.text.Document) */ @Override public List<Element> end(final WorkerContext ctx, final Tag tag, final List<Element> currentContent) { final Map<String, String> attributes = tag.getAttributes(); String src = attributes.get(HTML.Attribute.SRC); List<Element> elements = new ArrayList<Element>(1); if (null != src && src.length() > 0) { Image img = null; if (src.startsWith("data:image/")) { final String base64Data = src.substring(src.indexOf(",") + 1); try { img = Image.getInstance(Base64.decode(base64Data)); } catch (Exception e) { throw new RuntimeException(e); } if (img != null) { try { final HtmlPipelineContext htmlPipelineContext = getHtmlPipelineContext(ctx); elements.add(getCssAppliers().apply(new Chunk((com.itextpdf.text.Image) getCssAppliers().apply(img, tag, htmlPipelineContext), 0, 0, true), tag, htmlPipelineContext)); } catch (NoCustomContextException e) { throw new RuntimeWorkerException(e); } } } if (img == null) { elements = super.end(ctx, tag, currentContent); } } return elements; } } 字体类:
importcom.itextpdf.text.BaseColor; import com.itextpdf.text.Font; import com.itextpdf.text.FontFactory; import com.itextpdf.text.pdf.BaseFont; import com.itextpdf.tool.xml.XMLWorkerFontProvider; import com.thinkgem.jeesite.common.config.Global; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class AsianFontProvider extends XMLWorkerFontProvider { protected Logger logger = LoggerFactory.getLogger(AsianFontProvider.class); private static final String contractPdfFontLocation = Global.getConfig("contractPdfFontLocation"); public Font getFont(final String fontname, final String encoding, final boolean embedded, final float size, final int style, final BaseColor color) { try { FontFactory.register(contractPdfFontLocation + "/simhei.ttf"); Font font3 = FontFactory.getFont("simhei", BaseFont.IDENTITY_H, BaseFont.EMBEDDED, 12,style); return font3; } catch (Exception e) { logger.error("==========获取字体出现异常==========",e); } return null; } }
配置文件:contractPdfFontLocation=D:\\pdffonts PS:
<!-- httpclient --> <dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId>httpclient</artifactId> <version>4.5.2</version> <exclusions> <exclusion> <artifactId>commons-logging</artifactId> <groupId>commons-logging</groupId> </exclusion> </exclusions> </dependency> <dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId>httpcore</artifactId> <version>4.4.4</version> </dependency> <dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId>httpmime</artifactId> <version>4.5.2</version> </dependency>
public static String httpPostUrlForPdf(String url) { // 设置HTTP请求参数 String result = null; CloseableHttpClient client = HttpClients.createDefault(); HttpGet httpGet = new HttpGet(url); try { CloseableHttpResponse response = client.execute(httpGet); result = EntityUtils.toString(response.getEntity(), "UTF-8"); } catch (ClientProtocolException e) { logger.error("http接口调用异常:url is::" + url, e); return null; } catch (IOException e) { logger.error("http接口调用异常:url is::" + url, e); return null; } finally { try { client.close(); } catch (IOException e) { logger.error("http接口调用异常:url is::" + url, e); } } return result; }
相关推荐
1. **PDF生成**:iTextPDF支持从头开始创建PDF文档,可以添加文本、图像、表格、链接、注释等元素。通过`Document`对象来定义文档的基本结构,`Paragraph`、`Chunk`和`Font`等类用于控制文本的样式和布局,`Image`类...
在本文中,我们将深入探讨如何利用IText库生成这两种格式的文档,并通过实际的源码示例来理解其工作原理。 首先,让我们从PDF(Portable Document Format)开始。PDF是一种通用的文件格式,能够保留文档的原始格式...
本教程将详细讲解如何使用Itext库实现PDF文件的下载,包括通过系统路径下载和通过浏览器下载两种方式。 首先,我们需要了解Itext的基本用法。Itext提供了一系列的API,可以方便地创建PDF文档的各个元素,如文本、...
5. **使用示例**: 使用iTextPDF生成带表格和目录的中文PDF文档,通常会涉及以下步骤: - 引入必要的库:在项目中添加`iText-asian-5.2.0.jar`和`itextpdf-5.5.5.jar`。 - 创建PDF文档:使用`Document`类初始化一个...
`itext-asian-5.2.0.jar` 和 `itextpdf-5.5.5.jar` 是两个关键的Java库,专门解决这个问题。 `itext-asian-5.2.0.jar` 是iText库的一个扩展,主要针对亚洲语言的支持,包括中文、日文和韩文。这个库包含了处理中文...
在IT行业中,HTML和PDF是两种非常常见的文档格式。HTML用于网页展示,而PDF则用于打印和电子阅读,保持格式一致性。将HTML转换为PDF的需求很常见,例如生成报告、电子书或者用户手册。`iText`是一个强大的Java库,...
2. **事件驱动模型**:iText使用事件驱动模型处理PDF生成,允许开发者在特定的PDF生成阶段插入自定义行为,比如添加水印、元数据等。 3. **表单处理**:iText支持AcroForms,可以创建交互式PDF表单,用户可以在PDF...
这个库提供了丰富的API,使得开发者能够轻松地实现各种复杂的PDF生成需求。在本篇文章中,我们将深入探讨如何使用IText在Java环境中生成PDF文档。 首先,你需要在项目中引入IText库。如果是Maven项目,可以在pom....
这个压缩包包含两个重要的JAR文件:`itextpdf-5.5.12.jar`和`itext-asian-5.2.0.jar`,它们是iText库的不同版本,用于帮助Java程序创建、编辑和操作PDF文档。 首先,我们来详细了解一下`itextpdf-5.5.12.jar`。这是...
在数字化的时代,HTML和PDF两种格式在信息传递中占据了重要地位。HTML用于网页展示,而PDF则常用于文档保存和打印。然而,将HTML转换为PDF的需求时常出现,特别是在需要保持一致的布局和格式时。iText是一个著名的...
"itext-2.1.7源码包以及 解决iText生成pdf时中文标点存在行首问题的修改class" 这个标题提到了两个关键点。首先,`itext-2.1.7`是开源Java库iText的一个版本,用于创建、修改和操作PDF文档。这个版本的源码包提供了...
在IT行业中,生成PDF文档是常见的需求,特别是在报表...结合SpringBoot的自动化和Freemarker的模板能力,可以构建出高效、可维护的PDF生成系统。然而,要注意兼容性和性能优化,以确保在各种场景下都能得到满意的结果。
总的来说,iText结合xmlworker库提供了一种强大且灵活的方式来将HTML内容转换为PDF格式,适用于生成报告、电子书、发票等各种用途。在Java开发中,掌握这些工具的使用能极大地提升PDF文档处理能力。
在IT行业中,转换HTML到PDF是一项常见的需求,特别是在文档生成、报表导出或者网页保存为离线阅读格式时。iText是一个强大的Java库,能够帮助开发者实现这样的转换,并且支持包含中文字符和图像的处理。本篇文章将...
iTextPDF是iText项目的一部分,由iText Software Corp开发,它提供了丰富的API,使得开发人员可以轻松地进行PDF文档的生成、编辑和解析。iTextPDF-5.1.2.jar是这个库的一个版本,包含了核心功能,如创建PDF页面、...
1. **安装与引入**:首先,介绍如何将iTextPDF库引入到Java项目中,通常通过Maven或Gradle的依赖管理来实现。同时,可能会提到不同版本的兼容性和选择合适的版本。 2. **基本概念**:解释PDF文档的基本结构,如页面...
它支持流式和模型两种模式,前者适用于生成内容不确定或长度未知的情况,后者则适用于内容固定或已知的情况。在SpringMVC中,可以通过控制器方法返回一个`HttpServletResponse`,在这个响应中设置相应的头信息,指示...
总结起来,"Velocity+Itext导出PDF"是一种高效且灵活的方式,可以将动态数据和预定义的模板结合,生成高质量的PDF文档。通过熟练掌握这两个工具的使用,开发者可以创建出满足各种需求的PDF文档生成系统。
下面我们将详细讨论如何使用Apache POI和iTextPDF这两个库来完成Word到PDF的转换。 Apache POI是一个流行的Java库,用于读写Microsoft Office格式的文件,包括Word(.doc和.docx)。它提供了低级API(HSSF和XSSF)...