//一个是从html文件直接转,还一个注释部分是拼写html,而后转其实都一样
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.xhtmlrenderer.pdf.ITextFontResolver;
import org.xhtmlrenderer.pdf.ITextRenderer;
import com.lowagie.text.DocumentException;
import com.lowagie.text.pdf.BaseFont;
public class Html2pdf {
public void htmlCodeComeFromFile(String filePath, String pdfPath) throws IOException {
String url = new File(filePath).toURI().toURL().toString();
ITextRenderer renderer = new ITextRenderer();
ITextFontResolver font = renderer.getFontResolver();
File file = new File(filePath);
Document document = Jsoup.parse(file, "utf-8", "");
// 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>").append("<div>人员名单:</div>")
// .append("<table width=\"200\" border=\"1\">").append("<tr>")
// .append("<td>姓名:</td>").append("<td>年龄:</td>").append("</tr>")
// .append("<tr>").append("<td>张小三</td>").append("<td>25</td>")
// .append("</tr>").append("</table>");
// html.append("</body></html>");
try {
font.addFont("C:/WINDOWS/Fonts/simsun.ttc",
BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED);
renderer.setDocumentFromString(document.html());
//renderer.setDocument(url);
renderer.getSharedContext().setBaseURL("file:" + filePath);
renderer.layout();
FileOutputStream fos = new FileOutputStream(new File(pdfPath));
renderer.createPDF(fos);
fos.flush();
fos.close();
System.out.println("ok");
} catch (DocumentException e) {
e.printStackTrace();
}
}
public static void main(String[] args) throws IOException {
Html2pdf ih = new Html2pdf();
ih.htmlCodeComeFromFile("c:\\pdf\\welcome.html", "c:\\pdf\\welcome.pdf");
}
}