我遇到了与您完全相同的问题,并且已经解决。这是我的发现:
由于某些原因,wkhtmltopdf的输出将进入该进程的STDERR,而不是STDOUT。我已经通过从Java和perl调用wkhtmltopdf验证了这一点
因此,例如在Java中,您将必须执行以下操作:
//ProcessBuilder is the recommended way of creating processes since Java 1.5 //Runtime.getRuntime().exec() is deprecated. Do not use. ProcessBuilder pb = new ProcessBuilder("wkhtmltopdf.exe", htmlFilePath, pdfFilePath);Process process = pb.start();BufferedReader errStreamReader = new BufferedReader(new InputStreamReader(process.getErrorStream())); //not "process.getInputStream()" String line = errStreamReader.readLine(); while(line != null) { System.out.println(line); //or whatever else line = reader.readLine(); }附带说明一下,如果从Java派生一个进程,则必须从stdout和stderr流中读取(即使您不对其进行任何操作),因为否则,流缓冲区将被填充,并且该进程将挂起并且永远不会返回。
为了使代码更可靠,以防万一wkhtmltopdf的开发人员决定将其写入stdout,您可以将子进程的stderr重定向到stdout,并且仅读取如下流:
ProcessBuilder pb = new ProcessBuilder("wkhtmltopdf.exe", htmlFilePath, pdfFilePath); pb.redirectErrorStream(true); Process process = pb.start(); BufferedReader inStreamReader = new BufferedReader(new InputStreamReader(process.getInputStream()));实际上,在必须从Java派生外部进程的所有情况下,我都会这样做。这样,我不必阅读两个流。
如果您不希望主线程阻塞,则还应该在不同的线程中读取生成的进程的流,因为从流中读取是阻塞的。
希望这可以帮助。
更新
:我在项目页面中提出了这个问题,并回答说这是设计使然,因为wkhtmltopdf支持在STDOUT中提供实际的pdf输出。请参阅链接以获取更多详细信息和Java代码。



