0

升级到 MacOS Catalina 并链接到 10.15 SDK 中包含的 libxslt 和 libxml2 后,一个奇怪的问题是,所有的使用disable-output-escaping="yes"都被破坏了并且无论如何都会转义输出。来自各种 XSLT 工作表的几个示例:

<xsl:text disable-output-escaping="yes">&lt;--test comment--&gt;</xsl:text>
<xsl:value-of select="/*[1]/LBL_CM_3" disable-output-escaping="yes" />

节点中LBL_CM_3有一些 HTML,例如cm<sup>3</sup>. 当我的代码使用非常直接的 API 处理时,这两种情况都被转义(意外结果)。这是一个精简的版本,省略了错误检查和清理:

    xmlDocPtr tmpXmlDoc = xmlParseMemory(inputString.c_str(), (int)inputString.size());
    xmlDocPtr tmpXslDoc = xmlParseMemory(xslInputStr, xslInputStrSize);
    xsltStylesheetPtr tmpXslStyleSheet = xsltParseStylesheetDoc(tmpXslDoc);
    xmlDocPtr tmpHtmlDoc = xsltApplyStylesheet(tmpXslStyleSheet, tmpXmlDoc, params);

但是,如果我使用 处理相同的输入和样式表/usr/bin/xsltproc,则不会转义输出(预期结果)。我们都链接系统上的同一个库:

$ otool -L /usr/bin/xsltproc | grep -E 'xml|xslt'
/usr/bin/xsltproc:
    /usr/lib/libexslt.0.dylib (compatibility version 9.0.0, current version 9.15.0)
    /usr/lib/libxslt.1.dylib (compatibility version 3.0.0, current version 3.26.0)
    /usr/lib/libxml2.2.dylib (compatibility version 10.0.0, current version 10.9.0)
$ otool -L TestXslt.app/Contents/MacOS/TestXslt | grep -E 'xml|xslt'
    /usr/lib/libxml2.2.dylib (compatibility version 10.0.0, current version 10.9.0)
    /usr/lib/libexslt.0.dylib (compatibility version 9.0.0, current version 9.15.0)
    /usr/lib/libxslt.1.dylib (compatibility version 3.0.0, current version 3.26.0)

系统xsltproc版本信息:

$ /usr/bin/xsltproc --version
Using libxml 20904, libxslt 10129 and libexslt 817
xsltproc was compiled against libxml 20904, libxslt 10129 and libexslt 817
libxslt 10129 was compiled against libxml 20904
libexslt 817 was compiled against libxml 20904

10.15 SDKusr/include/libxml/xmlversion.h显示相同的版本:

/**
 * LIBXML_DOTTED_VERSION:
 *
 * the version string like "1.2.3"
 */
#define LIBXML_DOTTED_VERSION "2.9.4"

/**
 * LIBXML_VERSION:
 *
 * the version number: 1.2.3 value is 10203
 */
#define LIBXML_VERSION 20904

这与之前使用 MacOS Sierra SDK 的预期一样工作,具有相同的调用代码和相同的 XSLT 工作表。XSLT 处理的所有其余部分似乎都按预期工作,只是disable-output-escaping="yes"被忽略了。

4

1 回答 1

0

事实证明,这是由 另一个依赖项的冲突版本libxml2的混合链接引起的。libxslt系统版本:

libxml2.2.dylib (compatibility version 10.0.0, current version 10.9.0)
libxslt.1.dylib (compatibility version 3.0.0, current version 3.26.0)

带有预构建 Postgres 12 的捆绑版本:

libxml2.2.dylib (compatibility version 12.0.0, current version 12.4.0)
libxslt.1.dylib (compatibility version 3.0.0, current version 3.29.0)

如果您libxml2从 Postgres 获得了 eg ,但从libxslt系统获得了 ,那么它大部分都可以工作,但disable-output-escaping会神秘地中断。如果您使用任一对(两个系统,或都与 Postgres 捆绑),则disable-output-escaping可以。您必须考虑链接器排序(例如,otool -L如果存在多个版本,则报告。

于 2020-07-21T19:25:00.727 回答