304.4. OGNL 表达式支持


可作为 Camel 2.3 提供

INFO:Camel 的 OGNL 支持仅用于调用方法。您无法访问字段。从 Camel 2.11.1 开始,我们添加了对访问 Java 阵列长度字段的特例支持。

SimpleBean 语言现在支持 Camel OGNL 表示法在链中调用 Bean。假设 Message IN body 包含 POJO,它使用 getAddress () 方法。

然后,您可以使用 Camel OGNL 表示法访问地址对象:

simple("${body.address}")
simple("${body.address.street}")
simple("${body.address.zip}")
Copy to Clipboard Toggle word wrap

Camel 了解 getter 的短名称,但您可以调用任何方法或使用类似的实际名称:

simple("${body.address}")
simple("${body.getAddress.getStreet}")
simple("${body.address.getZip}")
simple("${body.doSomething}")
Copy to Clipboard Toggle word wrap

例如,如果正文没有地址,您可以使用 null 安全运算符()以避免 NPE

simple("${body?.address?.street}")
Copy to Clipboard Toggle word wrap

也可以以 MapList 类型索引,因此您可以:

simple("${body[foo].name}")
Copy to Clipboard Toggle word wrap

假设正文基于 Map,并使用 foo 作为键查找值,并在该值上调用 getName 方法。

如果键有空格,则必须使用 引号包括密钥,例如 'foo bar':

simple("${body['foo bar'].name}")
Copy to Clipboard Toggle word wrap

您可以使用密钥名称(带有或不带句点)直接访问 MapList 对象:

simple("${body[foo]}")
simple("${body[this.is.foo]}")
Copy to Clipboard Toggle word wrap

假设键为 foo 没有值,您可以使用 null 安全 Operator 以避免 NPE,如下所示:

simple("${body[foo]?.name}")
Copy to Clipboard Toggle word wrap

您还可以访问 列表 类型,例如从地址中获取行:

simple("${body.address.lines[0]}")
simple("${body.address.lines[1]}")
simple("${body.address.lines[2]}")
Copy to Clipboard Toggle word wrap

有一个特殊的 last 关键字,可用于从列表中获取最后一个值。

simple("${body.address.lines[last]}")
Copy to Clipboard Toggle word wrap

最后,您可以减去一个数字,因此我们可以使用 last-1 来指明这一点:

simple("${body.address.lines[last-1]}")
Copy to Clipboard Toggle word wrap

最后第三步是课程:

simple("${body.address.lines[last-2]}")
Copy to Clipboard Toggle word wrap

您可以在列表中调用 size 方法

simple("${body.address.lines.size}")
Copy to Clipboard Toggle word wrap

Camel 2.11.1 开始,我们增加了对 Java 阵列的长度字段的支持,例如:

String[] lines = new String[]{"foo", "bar", "cat"};
exchange.getIn().setBody(lines);

simple("There are ${body.length} lines")
Copy to Clipboard Toggle word wrap

和 yes,您可以将其与 Operator 支持合并,如下所示:

simple("${body.address.zip} > 1000")
Copy to Clipboard Toggle word wrap
返回顶部
Red Hat logoGithubredditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

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

让开源更具包容性

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

關於紅帽

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

Theme

© 2025 Red Hat