我怀疑你的问题出在getTagValue方法的以下代码行中:
Node nValue = (Node) nlList.item(0);
你总是得到第一个孩子!但是你可能不止一个.
以下示例有3个子节点:文本节点“detail”,CDATA节点“with cdata”和文本节点“here”:
detail here
如果你运行你的代码,你只得到“细节”,你就会失去其余部分.
以下示例有1个子节点:CDATA节点“此处带有cdata的详细信息”:
如果你运行你的代码,你会得到一切.
但是上面这样写的例子如下:
现在有3个孩子因为空格和换行被选为文本节点.如果您运行代码,则会获得带有换行符的第一个空文本节点,其余部分将丢失.
您要么遍历所有子项(无论多少)并连接每个子项的值以获得完整结果,或者如果区分纯文本和CDATA内的文本并不重要,则在上面设置合并属性文档制作工厂首先:
DocumentBuilderFactory docFactory = DocumentBuilderFactory.newInstance();
docFactory.setCoalescing(true);
...