出处:http://HdhCmsTestiteye测试数据
http://blog.csdn.net/zdtwyjp/article/details/5769353
http://HdhCmsTestxuebuyuan测试数据/2056017.html
1、IText实现html2pdf,速度快,纠错能力差,支持中文(要求HTML使用unicode编码),但中支持一种中文字体,开源。
2、Flying Sauser实现html2pdf,纠错能力差,支持多种中文字体(部分样式不能识别),开源。
3、PD4ML实现html2pdf,速度快,纠错能力强,支持多种中文字体,商业。
(一)IText
官网: http://HdhCmsTestitextpdf测试数据/
测试案例:TestIText.java
依赖jar包:iText-2.0.8.jar、iTextAsian.jar(支持中文)
下面只是一个小的测试案例,如果项目中使用到了该组件可以参考API完成项目组中相应的功能!
[c-sharp] view plain copy
import java.io.FileOutputStream; import java.io.FileReader; import java.util.ArrayList; import com.lowagie.text.Document; import com.lowagie.text.Element; import com.lowagie.text.Font; import com.lowagie.text.PageSize; import com.lowagie.text.Paragraph; import com.lowagie.text.html.simpleparser.HTMLWorker; import com.lowagie.text.html.simpleparser.StyleSheet; import com.lowagie.text.pdf.BaseFont; import com.lowagie.text.pdf.PdfWriter; public class TestIText{ public static void main(String[] args) { TestIText ih = new TestIText(); ih.htmlCodeComeFromFile("D://Test//iText.html", "D://Test//iText_1.pdf"); ih.htmlCodeComeString("Hello中文", "D://Test//iText_2.pdf"); } public void htmlCodeComeFromFile(String filePath, String pdfPath) { Document document = new Document(); try { StyleSheet st = new StyleSheet(); st.loadTagStyle("body", "leading", "16,0"); PdfWriter.getInstance(document, new FileOutputStream(pdfPath)); document.open(); ArrayList p = HTMLWorker.parseToList(new FileReader(filePath), st); for(int k = 0; k document.add((Element)p.get(k)); } document.close(); System.out.println("文档创建成功"); }catch(Exception e) { e.printStackTrace(); } } public void htmlCodeComeString(String htmlCode, String pdfPath) { Document doc = new Document(PageSize.A4); try { PdfWriter.getInstance(doc, new FileOutputStream(pdfPath)); doc.open(); // 解决中文问题 BaseFont bfChinese = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H", BaseFont.NOT_EMBEDDED); Font FontChinese = new Font(bfChinese, 12, Font.NORMAL); Paragraph t = new Paragraph(htmlCode, FontChinese); doc.add(t); doc.close(); System.out.println("文档创建成功"); }catch(Exception e) { e.printStackTrace(); } } }(二)Flying Sauser
项目主页: https://xhtmlrenderer.dev.java.net/
依赖jar包:iText-2.0.8.jar、iTextAsian.jar、core-renderer.jar
默认情况下,core-renderer.jar对中文是不能进行换行的,如果想解决换行问题可以去 http://bettereveryday.javaeye测试数据/blog/611561下载一个jar包,该包对源代码做了稍加修改.
下面只是一个小的测试案例,如果项目中使用到了该组件可以参考API完成项目组中相应的功能!
[c-sharp] view plain copy
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 TestFlyingSauser { public static void main(String[] args) throws Exception { demo_1(); demo_2(); } // 不支持中文 public static void demo_1() 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 demo_2() throws Exception { String outputFile = "D:/Test/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(" "); html.append(" ").append(" ") .append(" ") .append(" body {font-family: SimSun;} --> body {font-family: SimSun;} ") .append(" ") .append(" "); html.append("支持中文!
查看更多关于Java实现HTML代码生成PDF文档_html/css_WEB-ITnose的详细内容...