304.7. Samples


在以下 Spring XML 示例中,我们根据标头值过滤:

<from uri="seda:orders">
   <filter>
       <simple>${in.header.foo}</simple>
       <to uri="mock:fooOrders"/>
   </filter>
</from>

Simple 语言可用于消息过滤器模式的 predicate 测试,其中我们测试消息是否有 foo 标头(键为 foo 的标头存在)。如果表达式评估为 true,则消息将路由到 mock:fooOrders 端点,否则消息将被丢弃。

Java DSL 中的相同示例:

from("seda:orders")
    .filter().simple("${in.header.foo}")
        .to("seda:fooOrders");

您还可以将简单的语言用于简单的文本串联,例如:

from("direct:hello")
    .transform().simple("Hello ${in.header.user} how are you?")
    .to("mock:reply");

请注意,我们必须在表达式中使用 $\{ } 占位符,以允许 Camel 正确解析它。

此示例使用 date 命令输出当前日期。

from("direct:hello")
    .transform().simple("The today is ${date:now:yyyyMMdd} and it is a great day.")
    .to("mock:reply");

在以下示例中,我们调用 bean 语言,以调用要包含在返回字符串中的 bean 的方法:

from("direct:order")
    .transform().simple("OrderId: ${bean:orderIdGenerator}")
    .to("mock:reply");

其中 orderIdGenerator 是 registry 中注册的 bean 的 id。如果使用 Spring,则它是 Spring bean id。

如果要声明在 ID 生成器 Bean 上调用哪些方法,我们必须前置 .method 名称,如我们调用 generateId 方法的位置。

from("direct:order")
    .transform().simple("OrderId: ${bean:orderIdGenerator.generateId}")
    .to("mock:reply");

我们可以使用我们熟悉 Bean 组件本身的 ?method=methodname 选项:

from("direct:order")
    .transform().simple("OrderId: ${bean:orderIdGenerator?method=generateId}")
    .to("mock:reply");

从 Camel 2.3 开始,您还可以将正文转换为给定类型,例如,确保它是一个字符串,您可以:

<transform>
  <simple>Hello ${bodyAs(String)} how are you?</simple>
</transform>

有几个类型具有简写表示法,因此我们可以使用 String 而不是 java.lang.String。这些是: byte[]、String、Integer、Long。所有其他类型都必须使用其 FQN 名称,例如 org.w3c.dom.Document

也可以从 Camel 2.3 中的标头 映射 中查找值:

<transform>
  <simple>The gold value is ${header.type[gold]}</simple>
</transform>

在上面的代码中,我们查找名称 type 的标头并将其视为 java.util.Map,然后以键 金级 进行查找并返回值。如果标头不可转换为 Map 异常,则会抛出异常。如果名为 type 的标头不存在,则返回 null

从 Camel 2.9 开始,您可以嵌套功能,如下所示:

<setHeader headerName="myHeader">
  <simple>${properties:${header.someKey}}</simple>
</setHeader>
Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

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

让开源更具包容性

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

關於紅帽

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

© 2024 Red Hat, Inc.