我使用JAXP构建了一个文档,如下所示:
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document document = builder.newDocument();
Element rootElement = document.createElement("Root");
for (MyObject o : myCollection) {
Element entry = document.createElement("Entry");
Element entryItem = document.createElement("EntryItem");
entryItem.appendChild(document.createTextNode(o.getProperty()));
entry.appendChild(entryItem);
rootElement.appendChild(entry);
}
document.appendChild(rootElement);
现在,当我尝试输出文档的XML时,如下所示:
Transformer transformer = TransformerFactory.newInstance().newTransformer();
transformer.setOutputProperty(OutputKeys.INDENT, "yes");
DOMSource source = new DOMSource(document);
StreamResult result = new StreamResult(new StringWriter());
transformer.transform(source, result);
System.out.println(result.getWriter().toString());
它在transformer.transform行上崩溃,出现以下错误:
FATAL ERROR: 'java.lang.NullPointerException'
:null
我该如何调试呢?我确保变换器,源和结果不为空.
最佳答案 我猜这个:
entryItem.appendChild(document.createTextNode(o.getProperty()));
创建了一个空值的文本节点.查看Xerces的代码(这是Oracle JDK 1.6附带的默认JAXP实现),我发现在构造文本节点时没有完成空验证.我怀疑,后来,这让Transformer死了.
要么是,要么存在一些JAXp配置问题.
您可能希望设置jaxp.debug系统属性(可用JDK 1.6)以获取一些JAXP跟踪信息.