gpt4 book ai didi

java - HTML 到 PDF 转换 - "Can' t 加载 XML 资源“错误

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:34:56 25 4
gpt4 key购买 nike

我正在尝试使用 Flying Saucer 和 iText 将严格的 XHTML 转换为 PDF。我已经验证了 XHTML,并且输入和输出文件的路径是准确的。我完全不知道为什么这会在 renderer.setDocument("file:/c:/example/First.html") 行上抛出异常。

我的类(class):

package flyingsaucerpdf;
import java.io.*;
import org.xhtmlrenderer.pdf.ITextRenderer;
import com.lowagie.text.DocumentException;

public class FirstDoc {
public static void main(String[] args) throws IOException, DocumentException
{
String outputFile = "results/firstdoc.pdf";
OutputStream os = new FileOutputStream(outputFile);
ITextRenderer renderer = new ITextRenderer();
try
{
renderer.setDocument("file:/c:/example/First.html");
}
catch( Exception e )
{
System.out.println("Me not create file. Error:"+e.getMessage());
}
renderer.layout();
renderer.createPDF(os);

os.close();
}

}

我的异常(exception):

错误:''我没有创建文件。错误:无法加载 XML 资源(使用 TRaX 转换器)。 java.lang.NullPointerException

线程“main”中的异常 java.lang.NullPointerException 在 org.xhtmlrenderer.layout.BoxBuilder.createRootBox(BoxBuilder.java:81) 在 org.xhtmlrenderer.pdf.ITextRenderer.layout(ITextRenderer.java:152) 在 flyingsaucerpdf.FirstDoc.main(FirstDoc.java:31)

我的 XHTML:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>Insert title here</title>
<style type="text/css"> b { color: green; } </style>
</head>
<body>
<p>
<b>Greetings Earthlings!</b>
We've come for your Java.
</p>
</body>
</html>

有什么帮助吗?

最佳答案

您的虚拟机在线吗?渲染器/解析器可能会尝试加载链接资源,例如

http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd

确保您提供的 xml (xhtml) 是正确的。

在 Servlet 中,我执行了以下似乎有效的操作(一些在线资源在我自己的文件系统中可用,因为服务器没有互联网连接):

final DocumentBuilder builder = DocumentBuilderFactory.newInstance().newDocumentBuilder();
builder.setEntityResolver(new EntityResolver() {
@Override
public InputSource resolveEntity(String publicId, String systemId)
throws SAXException, IOException {
if (systemId.contains("xhtml1-transitional.dtd")) {
return new InputSource(new FileReader(realPath + "/WEB-INF/dtd/xhtml1-transitional.dtd"));
} else if (systemId.contains("xhtml-lat1.ent")) {
return new InputSource(new FileReader(realPath + "/WEB-INF/dtd/xhtml-lat1.ent"));
} else if (systemId.contains("xhtml-symbol.ent")) {
return new InputSource(new FileReader(realPath + "/WEB-INF/dtd/xhtml-symbol.ent"));
} else if (systemId.contains("xhtml-special.ent")) {
return new InputSource(new FileReader(realPath + "/WEB-INF/dtd/xhtml-special.ent"));
} else {
return null;
}
}
});
final ByteArrayInputStream inputStream = new ByteArrayInputStream(html.getBytes("UTF-8"));
final Document doc = builder.parse(inputStream);
inputStream.close();
final ITextRenderer renderer = new ITextRenderer(26f * 4f / 3f, 26);
renderer.setDocument(doc, request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort());
renderer.layout();

这基本上设置了一个 DocumentBuilder,然后解析我的文档(它是字符串格式并由变量 html 表示)

关于java - HTML 到 PDF 转换 - "Can' t 加载 XML 资源“错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9415468/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com