32.5. 启用 Saxon


先决条件

使用 Saxon 解析器的先决条件是,您可以添加对 camel-saxon 工件的依赖关系(如果使用 Maven,或将 camel-saxon-2.23.2.fuse-7_10_0-00018-redhat-00001.jar 文件添加到您的类路径),否则为类路径添加 camel-saxon-2.23.2。

在 Java DSL 中使用 Saxon parser

在 Java DSL 中,启用 Saxon parser 最简单的方法是调用 saxon () fluent builder 方法。例如,您可以调用 Saxon parser,如下例所示:

// Java
// create a builder to evaluate the xpath using saxon
XPathBuilder builder = XPathBuilder.xpath("tokenize(/foo/bar, '_')[2]").saxon();

// evaluate as a String result
String result = builder.evaluate(context, "<foo><bar>abc_def_ghi</bar></foo>");

在 XML DSL 中使用 Saxon parser

在 XML DSL 中,启用 Saxon parser 最简单的方法是将 xpath 元素中的 saxon 属性设置为 true。例如,您可以调用 Saxon parser,如下例所示:

<xpath saxon="true" resultType="java.lang.String">current-dateTime()</xpath>

使用 Saxon 进行编程

如果要在应用程序代码中使用 Saxon XML 解析器,则可使用以下代码明确创建一个 Saxon transformer factory 实例:

// Java
import javax.xml.transform.TransformerFactory;
import net.sf.saxon.TransformerFactoryImpl;
...
TransformerFactory saxonFactory = new net.sf.saxon.TransformerFactoryImpl();

另一方面,如果您更喜欢使用通用 JAXP API 创建转换器工厂实例,您必须首先在 ESBInstall/etc/system.properties 文件中设置 javax.xml.transform.TransformerFactory 属性,如下所示:

javax.xml.transform.TransformerFactory=net.sf.saxon.TransformerFactoryImpl

然后,您可以使用通用 JAXP API 实例化 Saxon 工厂,如下所示:

// Java
import javax.xml.transform.TransformerFactory;
...
TransformerFactory factory = TransformerFactory.newInstance();

如果您的应用程序依赖于使用 Saxon 的任何第三方库,可能需要使用第二个通用方法。

注意

Saxon 库必须作为 OSGi 捆绑包安装到容器中,net.sf.saxon/saxon9he (通常默认安装)。在 7.1 之前的 Fuse ESB 版本中,无法使用通用 JAXP API 加载 Saxon。

Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

© 2024 Red Hat, Inc.