1

我尝试使用 Saxon 代替 JDK 的默认实现(我猜是 Xalan)来进行 XML 转换和 Xpath。在我的代码中,我正在使用 document.createCDATASection(data) 方法创建一个 CDATA 节点。代码如下所示:

    CDATASection cdata = doc.createCDATASection("data");
    Node valueNode = node.appendChild(doc.createElement("value"));
    valueNode.appendChild(cdata);

其中 node 是我的 XML 中的某个随机节点。它适用于 JDK 的默认实现,生成的 XML 如下所示:

            <node>
             <value><![CDATA[data]]></value>
            </node>

如果我包含 Saxon maven 工件,相同的代码开始表现得很奇怪(请注意,它只是包含,工厂选择/实例化是默认的,就像之前一样)并且所有 cdata 节点都被视为简单的文本节点,即 XML 变为:

            <node>
             <value>data</value>
            </node>

检索时会导致问题,因为该代码专门检查 cdata 元素,这些元素在以后的情况下已被删除。我不确定为什么会发生这种情况(看起来我没有正确使用它)。我还尝试从我的 POM(Saxon 的传递依赖项)中排除 Xerces 工件,但没有运气。此外,验证了 JDK 本身正在使用 DocumentBuilderFactory 等的实现类。如果我做错了什么,请专家帮助我。

提前致谢。

4

1 回答 1

1

我猜您的应用程序可能正在执行从 DOMSource 到 StreamResult 的 JAXP 身份转换,以便序列化 DOM。JAXP 身份转换的 Saxon 实现使用 XSLT 的序列化规则,这些规则具有删除 CDATA 部分的效果。这与 JAXP 完全一致,即使它不是默认的 JDK 实现所做的。

如果您依赖于 JAXP 身份转换器的特定实现的行为,那么您不应该编写应用程序来获取恰好位于类路径上的任何实现。你应该明确地实例化你想要的实现。

如果调用恒等变换的代码不是您自己编写的并且不能轻易更改,这当然会很困难。在这种情况下,最好的方法是将系统属性 javax.xml.transform.TransformerFactory 设置为选择 Xalan,并且在您想要调用 Saxon 的地方显式执行此操作,而不是依赖 JAXP 工厂搜索。

于 2013-06-06T18:28:03.480 回答