c 将html转换为pdf,利用itext将html转为pdf

亲测代码没有问题,需要注意细节已经标注;需要jar包:iText-2.0.8.jar;core-renderer-R8.jar;

import com.lowagie.text.pdf.BaseFont;

import org.xhtmlrenderer.pdf.ITextFontResolver;

import org.xhtmlrenderer.pdf.ITextRenderer;

import java.io.File;

import java.io.FileOutputStream;

import java.io.OutputStream;

public class HtmlToPDF {

public static void main(String[] args) throws Exception {

htmlToPdf("C://Users//Administrator//Desktop//20181001.pdf","C://Users//Administrator//Desktop//xse//newFile.html");

}

/**

* 把URL转换为PDF

* @param outputFile

* , 示例:/data/fs/inspector/BJ20150522001.pdf

* @param url

* ,示例:http :xxxx

* @return

* @throws Exception

*/

public static void htmlToPdf(String outputFile, String url)throws Exception {

try{

OutputStream os = new FileOutputStream(outputFile);

ITextRenderer renderer = new ITextRenderer();

// 如果携带图片则加上以下代码,将图片标签转换为Itext自己的图片对象

renderer.getSharedContext().setReplacedElementFactory(new Base64ImgReplacedElementFactory());

renderer.getSharedContext().getTextRenderer().setSmoothingThreshold(0);

//String fontPath = HtmlToPDF.class.getClassLoader().getResource("").toString().replaceAll("file:/", "C:\\Users\\Administrator\\Downloads\\simsunttc\\") + "simsun.ttc";

// 解决中文支持问题 字体必须名称必须和前台页面的大小写一直(simsun 区分大小写)

String fontPath="C:\\Users\\Administrator\\Downloads\\simsunttc\\simsun.ttc";

ITextFontResolver fontResolver = renderer.getFontResolver();

fontResolver.addFont(fontPath, BaseFont.IDENTITY_H,BaseFont.NOT_EMBEDDED);

url=new File(url).toURI().toURL().toString();

renderer.setDocument(url);

//解决图片相对路径问题,window 上必须用file:/; 后面路径只写到img标签中src的上级目录

renderer.getSharedContext().setBaseURL("file:/C:/Users/Administrator/Desktop/xse/");

renderer.layout();

renderer.createPDF(os);

os.flush();

os.close();

}catch(Exception e ){

e.printStackTrace();

}

}

}

import com.lowagie.text.BadElementException;

import com.lowagie.text.Image;

import com.lowagie.text.pdf.codec.Base64;

import org.w3c.dom.Element;

import org.xhtmlrenderer.extend.FSImage;

import org.xhtmlrenderer.extend.ReplacedElement;

import org.xhtmlrenderer.extend.ReplacedElementFactory;

import org.xhtmlrenderer.extend.UserAgentCallback;

import org.xhtmlrenderer.layout.LayoutContext;

import org.xhtmlrenderer.pdf.ITextFSImage;

import org.xhtmlrenderer.pdf.ITextImageElement;

import org.xhtmlrenderer.render.BlockBox;

import org.xhtmlrenderer.simple.extend.FormSubmissionListener;

import java.io.IOException;

/**

*  * 图片base64支持,把图片转换为itext自己的图片对象

*  * @author Administrator

*  *

*

*/

public class Base64ImgReplacedElementFactory implements ReplacedElementFactory {

/**

*  * 实现createReplacedElement 替换html中的Img标签

*  *

*  * @param c 上下文

*  * @param box 盒子

*  * @param uac 回调

*  * @param cssWidth css宽

*  * @param cssHeight css高

*  * @return ReplacedElement

*

*/

public ReplacedElement createReplacedElement(LayoutContext c, BlockBox box, UserAgentCallback uac,int cssWidth, int cssHeight) {

Element e = box.getElement();

if (e == null) {

return null;

}

String nodeName = e.getNodeName();

// 找到img标签

if (nodeName.equals("img")) {

String attribute = e.getAttribute("src");

FSImage fsImage;

try {

// 生成itext图像

fsImage = buildImage(attribute, uac);

} catch (BadElementException e1) {

fsImage = null;

} catch (IOException e1) {

fsImage = null;

}

if (fsImage != null) {

// 对图像进行缩放

if (cssWidth != -1 || cssHeight != -1) {

fsImage.scale(cssWidth, cssHeight);

}

return new ITextImageElement(fsImage);

}

}

return null;

}

/**

*  * 编解码base64并生成itext图像

*

*/

protected FSImage buildImage(String srcAttr, UserAgentCallback uac) throws IOException,

BadElementException {

FSImage fiImg = null;

if (srcAttr.toLowerCase().startsWith("data:image/")) {

String base64Code = srcAttr.substring(srcAttr.indexOf("base64,") + "base64,".length(), srcAttr.length());

// 解码

byte[] decodedBytes = Base64.decode(base64Code);

fiImg = new ITextFSImage(Image.getInstance(decodedBytes));

} else {

fiImg = uac.getImageResource(srcAttr).getImage();

}

return fiImg;

}

public void reset() {

}

@Override

public void remove(Element arg0) {

}

@Override

public void setFormSubmissionListener(FormSubmissionListener arg0) {

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: itextpdf是一个用于处理PDF文件的Java库,它可以将含有图片的HTML文件转换PDF格式。 首先,我们需要获取包含图片的HTML文件。使用itextpdf库提供的HtmlConverter类,我们可以通过调用其convertToPdf方法将HTML文件转换PDF文件。代码示例如下: ```java import com.itextpdf.html2pdf.HtmlConverter; public class HtmlToPdfConverter { public static void main(String[] args) { String htmlFile = "path/to/input.html"; String pdfFile = "path/to/output.pdf"; try { HtmlConverter.convertToPdf(new File(htmlFile), new File(pdfFile)); System.out.println("HTMLPDF成功!"); } catch (IOException e) { System.out.println("转换过程中出现异常:" + e.getMessage()); } } } ``` 上述代码中,htmlFile是需要转换HTML文件路径,pdfFile是转换后的PDF文件路径。使用convertToPdf方法,即可将HTML文件转换PDF文件。 在转换的过程中,itextpdf会处理HTML文件中的图片,并将其插入到生成的PDF文件中。请注意,转换过程可能会受到HTML文件中嵌入图片的格式、大小等因素的影响。 ### 回答2: itextpdf是一个开源的Java库,可以用来生成PDF文件。使用itextpdf将含有图片的HTML转为PDF的步骤如下: 1. 首先,你需要将含有图片的HTML文件加载到一个String变量中。 2. 创建一个Document对象,并将其作为参数传递给PdfWriter对象,以便将内容写入PDF文件。 3. 使用HTMLWorker类的getInstance()方法创建HTMLWorker对象。HTMLWorker类是itextpdf库的一个类,用于解析和处理HTML。 4. 调用HTMLWorker对象的parse()方法,将HTML字符串作为参数传递给它。这将解析HTML字符串并将其转换PDF。 5. 使用Image类的getInstance()方法加载图片文件,并将其添加到PDF中。你可以使用Image对象的setAbsolutePosition()方法设置图片的位置。 6. 最后,关闭Document对象和PdfWriter对象,以确保生成的PDF文件保存。 以下是一个示例代码: ```java import com.itextpdf.text.Document; import com.itextpdf.text.DocumentException; import com.itextpdf.text.Image; import com.itextpdf.text.pdf.PdfWriter; import com.itextpdf.text.html.simpleparser.HTMLWorker; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; public class HtmlToPdfConverter { public static void main(String[] args) { String html = "<html><body><h1>这是一个含有图片的HTML文件</h1><img src='path_to_image_file' /></body></html>"; Document document = new Document(); try { PdfWriter writer = PdfWriter.getInstance(document, new FileOutputStream("output.pdf")); document.open(); HTMLWorker htmlWorker = new HTMLWorker(document); htmlWorker.parse(html); Image image = Image.getInstance("path_to_image_file"); image.setAbsolutePosition(100, 100); document.add(image); document.close(); writer.close(); System.out.println("PDF文件生成成功。"); } catch (DocumentException | IOException e) { e.printStackTrace(); } } } ``` 请注意,在代码示例中,你需要将"path_to_image_file"替换为实际图片文件的路径。 这就是使用itextpdf将含有图片的HTML转为PDF的基本步骤。你可以根据自己的需要对代码进行修改和适配。 ### 回答3: iTextPDF是一个用于将HTML转换PDF格式的Java库。它提供了许多功能和接口,可以方便地在应用程序中对HTML内容进行操作,并将其转换为可打印的PDF文件。 要使用iTextPDF将含有图片的HTML转换PDF,首先需要将HTML代码加载到一个String变量中。可以使用Java中的各种方法读取HTML文件或从网络获取HTML内容。接下来,创建一个空白的PDF文档对象并设置其属性,例如页面大小和边距。 然后,使用iTextPDF提供的HTML Converter类将HTML代码转换PDF格式。可以通过使用`HtmlConverter.convertToPdf()`方法来实现。此方法需要传入两个参数,第一个参数是HTML代码的InputStream流,第二个参数是输出PDF文件的OutputStream流。可以使用`IOUtils`类或其他I/O库将HTML代码和PDF文件的流传递给此方法。 在转换的过程中,iTextPDF将自动处理HTML中的图片。可以在HTML代码中使用img标签来插入图片,iTextPDF将自动将该图片提取并嵌入到生成的PDF文件中。确保在HTML代码中提供图片的正确路径或URL。 转换完成后,关闭输入和输出流,并保存或打印生成的PDF文件。可以使用Java中的文件操作API将输出流保存到指定的文件路径。 总结来说,使用iTextPDF将含有图片的HTML转换PDF的步骤如下: 1. 将HTML代码加载到一个String变量中。 2. 创建一个空白的PDF文档对象并设置其属性。 3. 使用iTextPDFHTML Converter类将HTML代码转换PDF格式。 4. 传入HTML代码的InputStream流和输出PDF文件的OutputStream流。 5. 关闭输入和输出流,并保存或打印生成的PDF文件。 通过这些步骤,我们可以方便地使用iTextPDF将含有图片的HTML转换PDF文件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值