我是org.xhtmlrenderer.pdf.ITextRenderer
的新手,遇到了这个问题:
我的测试servlet流到我的下载文件夹的PDF实际上是空文件。
相关方法streamAndDeleteTheClob
如下所示。
第一个尝试块肯定不是问题。
服务器在第二个try块中花费了大量时间。没有例外。
有人可以建议解决这个问题或者调试它的好方法吗?
有人能指出基本相似的代码吗?
非常感谢任何帮助。
res.setContentType("application/pdf");
ServletOutputStream out = res.getOutputStream();
...
private boolean streamAndDeleteTheClob(int pageid,
Connection con,
ServletOutputStream out) throws IOException, ServletException {
Statement statement;
Clob htmlpage;
StringBuffer pdfbuf = new StringBuffer();
final String pageToSendQuery = "SELECT text FROM page WHERE pageid = " + pageid;
// create xhtml file as a CLOB (Oracle large character object) and stream it into StringBuffer pdfbuf
try { // definitely no problem in this block
statement = con.createStatement();
resultSet = statement.executeQuery(pageToSendQuery);
if (resultSet.next()) {
htmlpage = resultSet.getClob(1);
} else {
return true;
}
final Reader in = htmlpage.getCharacterStream();
final char[] buffer = new char[4096];
while ((in.read(buffer)) != -1) {
pdfbuf.append(buffer);
}
} catch (Exception ex) {
out.println("buffering CLOB failed: " + ex);
}
// create pdf from StringBuffer
try {
DocumentBuilder builder = DocumentBuilderFactory.newInstance().newDocumentBuilder();
Document doc = builder.parse(new InputSource(new StringReader(pdfbuf.toString())));
ITextRenderer renderer = new ITextRenderer();
renderer.setDocument(doc, null);
renderer.layout();
renderer.createPDF(out);
out.close();
} catch (Exception ex) {
out.println("streaming of pdf failed: " + ex);
}
deleteClob(con, pageid);
return false;
}
答案 0 :(得分:2)
使用DocumentBuilder.parse这种方式将尝试解析XHTML页面中引用的DTD。这需要很长时间。如果您使用Flying Saucer(xhtmlrenderer),最简单的方法是以这种方式创建文档:
Document myDocument = XMLResource.load(myInputStream).getDocument();
请注意,您也可以将XMLResource.load与Reader配合使用。
答案 1 :(得分:0)
我能想到的两件事。
1)如果未关闭iText文档,它将为空。看起来renderer.finish()
会起作用,但createPDF(out)
应该已经这样做了。
2)如果没有页面,你也可以获得一个空文档......所以空输入可能会产生一个0字节的PDF。
3)您可能正在获得一个完全无效的PDF文件。尝试写入ByteArrayOutputStream并检查那里的长度。
4)对教皇几乎狂热的奉献!