77.3. OGNL 表达式支持


使用 OGNL 时,需要 camel-bean JAR 在 classpath 上。

Camel 的 OGNL 支持仅用于调用方法。您无法访问字段。Camel 支持访问 Java 阵列的长度字段。

Simple 和 Bean 语言现在支持 Camel OGNL 表示法,用来以类似方式的链调用 Bean。假设 Message IN 正文包含一个 POJO,它具有 getAddress () 方法。

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

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

Camel 了解 getters 的短名称,但您可以调用任何方法或使用实际名称,例如:

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

假设正文基于 映射,并使用 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 安全运算符来避免 NPE,如下所示:

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

您还可以访问 List 类型,例如从您可以做的地址获取行:

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

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

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

您可以使用方法调用列表的大小方法

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

Camel 还支持 Java 阵列的 length 字段,例如:

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

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

另外,您可以将此功能与 Operator 支持合并,如下所示:

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

学习

尝试、购买和销售

社区

关于红帽文档

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

让开源更具包容性

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

關於紅帽

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

Theme

© 2025 Red Hat