使用Java 将html转换PDF

package cn.spring.test.htmltopdf;


import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStream;


import org.xhtmlrenderer.pdf.ITextFontResolver;
import org.xhtmlrenderer.pdf.ITextRenderer;


import com.lowagie.text.pdf.BaseFont;


public class HtmltoPDF {

public static void main( String[] args ) throws Exception{
 
 
// htmlToPdf();
// htmlToPdf2();
htmlToPdf3();
   }   
 
   // 不支持中文   
   public static void htmlToPdf() throws Exception   
   {   
       String inputFile = "D:/Test/flying.html"; 
       String url = new File( inputFile ).toURI().toURL().toString();   
       String outputFile = "D:/Test/flying.pdf";   
       OutputStream os = new FileOutputStream( outputFile );   
       ITextRenderer renderer = new ITextRenderer();   
       renderer.setDocument( url );   
       renderer.layout();   
       renderer.createPDF( os );   
       os.close();   
   }   
 
   // 支持中文   
   public static void htmlToPdf2() throws Exception {     
       String outputFile = "F:/TestDemo/demo_3.pdf";     
       OutputStream os = new FileOutputStream(outputFile);     
       ITextRenderer renderer = new ITextRenderer();     
       ITextFontResolver fontResolver = renderer.getFontResolver();     
       fontResolver.addFont("C:/Windows/fonts/simsun.ttc", BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED);     
       StringBuffer html = new StringBuffer();     
       // DOCTYPE 必需写否则类似于 这样的字符解析会出现错误     
       html.append("<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">");     
       html.append("<html xmlns=\"http://www.w3.org/1999/xhtml\">").   
            append("<head>")     
           .append("<meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />")   
           .append("<style type=\"text/css\" mce_bogus=\"1\">body {font-family: SimSun;}</style>")    
           .append("</head>")     
           .append("<body>");     
       html.append("<div>支持中文!</div>");     
       html.append("</body></html>");     
       renderer.setDocumentFromString(html.toString());     
       // 解决图片的相对路径问题     
       // renderer.getSharedContext().setBaseURL("file:/F:/teste/html/");     
       renderer.layout();     
       renderer.createPDF(os);
       System.out.println("======转换成功!");
       os.close();     
   }
   
   public static void htmlToPdf3() throws Exception{
    String inputFile = "F:/TestDemo/test.html"; //本地目录必须html语言否则报错
    String outFile = "F:/TestDemo/test.pdf";
    OutputStream os = null;
    os =  new FileOutputStream(outFile);
    ITextRenderer renderer = new ITextRenderer();
    ITextFontResolver fontResolver = renderer.getFontResolver();
    fontResolver.addFont("C:/Windows/fonts/simsun.ttc", BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED);
   
    String url = new File( inputFile ).toURI().toURL().toString();
    System.out.println("=============url: "+url);
    renderer.setDocument(url);
    renderer.layout();
    renderer.createPDF(os);
    System.out.println("======转换成功!");
os.close();
   }


}


所需Jar包:

core-renderer.jar http://download.csdn.net/detail/hackxiaof/9257649

iText-2.0.8.jar  http://download.csdn.net/detail/hackxiaof/9257661





Java中将HTML转换PDF,可以使用一些专门的库,例如iText、Apache PDFBox、Flying Saucer等。以下是使用iText的一个简单示例: 首先,确保已经添加了iText的依赖。如果使用Maven,可以在`pom.xml`里加入: ```xml <dependency> <groupId>com.itextpdf</groupId> <artifactId>itextpdf</artifactId> <version>最新版本号</version> </dependency> ``` 然后,你可以编写这样的Java代码片段: ```java import com.itextpdf.text.Document; import com.itextpdf.text.Paragraph; import com.itextpdf.text.pdf.PdfWriter; import javax.servlet.http.HttpServletResponse; import java.io.IOException; public class HtmlToPdf { public void convert(HttpServletResponse response) throws IOException { Document document = new Document(); PdfWriter.getInstance(document, response.getOutputStream()); document.open(); // 获取HTML内容 String htmlContent = ...; // 这部分需要从HTML源获取 // 使用iText将HTML转换PDF com.itextpdf.html.purifier.Purifier purifier = new com.itextpdf.html.purifier.Purifier.Builder().build(); com.itextpdf.html.parser.ParseOptions options = new com.itextpdf.html.parser.ParseOptions(Purifier.ALLOW_ALL); com.itextpdf.html.parser.SimpleParser parser = new com.itextpdf.html.parser.SimpleParser(htmlContent, purifier, options); com.itextpdf.html.parser.ParseContext parseContext = new com.itextpdf.html.parser.ParseContext(document.getStyleSheet(), document); Element element = parser.parseDocument(parseContext); // 将HTML元素添加到PDF for (Element block : element.getDocument()) { if (block instanceof Paragraph) { document.add((Paragraph) block); } } document.close(); } } ``` 这段代码会在HTTP响应中返回PDF文件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值