html页面导出到pdf,如何将html页面导出为pdf格式?

Ravinder Red..

31

Flying Saucer API与iText PDF您一起使用可以将HTML内容转换为PDF.

以下示例可帮助您在一定程度上理解XHTML到PDF的转换.

示例使用Flying Saucer API:

您需要以下库:

核心renderer.jar

iText的 - 2.0.8.jar

示例1:使用XML资源:

// if you have html source in hand, use it to generate document object

Document document = XMLResource.load( new ByteArrayInputStream( yourXhtmlContentAsString.getBytes() ) ).getDocument();

ITextRenderer renderer = new ITextRenderer();

renderer.setDocument( document, null );

renderer.layout();

String fileNameWithPath = outputFileFolder + "PDF-XhtmlRendered.pdf";

FileOutputStream fos = new FileOutputStream( fileNameWithPath );

renderer.createPDF( fos );

fos.close();

System.out.println( "File 1: '" + fileNameWithPath + "' created." );

示例2:使用XHTML直接输入到Document:

ITextRenderer renderer = new ITextRenderer();

// if you have html source in hand, use it to generate document object

renderer.setDocumentFromString( yourXhtmlContentAsString );

renderer.layout();

String fileNameWithPath = outputFileFolder + "PDF-FromHtmlString.pdf";

FileOutputStream fos = new FileOutputStream( fileNameWithPath );

renderer.createPDF( fos );

fos.close();

System.out.println( "File 2: '" + fileNameWithPath + "' created." );

示例使用iText API:

您需要以下库:

核心renderer.jar

itextpdf-5.2.1.jar

您可以在此处找到这些资源.

示例3:使用HTML Worker:

com.itextpdf.text.Document document =

new com.itextpdf.text.Document( com.itextpdf.text.PageSize.A4 );

String fileNameWithPath = outputFileFolder + "PDF-HtmlWorkerParsed.pdf";

FileOutputStream fos = new FileOutputStream( fileNameWithPath );

com.itextpdf.text.pdf.PdfWriter pdfWriter =

com.itextpdf.text.pdf.PdfWriter.getInstance( document, fos );

document.open();

//**********************************************************

// if required, you can add document meta data

document.addAuthor( "Ravinder" );

//document.addCreator( creator );

document.addSubject( "HtmlWoker Parsed Pdf from iText" );

document.addCreationDate();

document.addTitle( "HtmlWoker Parsed Pdf from iText" );

//**********************************************************/

com.itextpdf.text.html.simpleparser.HTMLWorker htmlWorker =

new com.itextpdf.text.html.simpleparser.HTMLWorker( document );

htmlWorker.parse( new StringReader( sb.toString() ) );

document.close();

fos.close();

System.out.println( "File 3: '" + fileNameWithPath + "' created." );

@Ravinder我希望我能给你+100.我花了很多时间处理这个,我用过的所有不同的杂乱库等等.非常感谢! (2认同)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值