26.6. JMS 和 Camel 之间的消息映射


Camel 自动映射 javax.jms.Messageorg.apache.camel.Message 之间的消息。

发送 JMS 消息时,Camel 会将邮件正文转换为以下 JMS 消息类型:

正文类型JMS 消息注释

字符串

javax.jms.TextMessage

 

org.w3c.dom.Node

javax.jms.TextMessage

DOM 将转换为 字符串

Map

javax.jms.MapMessage

 

java.io.Serializable

javax.jms.ObjectMessage

 

byte[]

javax.jms.BytesMessage

 

java.io.File

javax.jms.BytesMessage

 

java.io.Reader

javax.jms.BytesMessage

 

java.io.InputStream

javax.jms.BytesMessage

 

java.nio.ByteBuffer

javax.jms.BytesMessage

 

收到 JMS 消息时,Camel 会将 JMS 消息转换为以下正文类型:

JMS 消息正文类型

javax.jms.TextMessage

字符串

javax.jms.BytesMessage

byte[]

javax.jms.MapMessage

map<String, Object>

javax.jms.ObjectMessage

对象

26.6.1. 禁用 JMS 消息的自动映射

您可以使用 mapJmsMessage 选项禁用上面的 auto-mapping。如果禁用,Camel 不会尝试映射收到的 JMS 消息,而是直接将其用作载荷。这可让您避免映射开销,让 Camel 仅通过 JMS 消息。例如,它甚至允许您路由带有使用了没有包括在 classpath 中的类的 javax.jms.ObjectMessage JMS 消息。

26.6.2. 使用自定义 MessageConverter

您可以使用 messageConverter 选项自己在 Spring org.springframework.jms.support.converter.MessageConverter 类中进行映射。

例如,在以下路由中,在向 JMS 顺序队列发送消息时,我们使用自定义消息转换程序:

from("file://inbox/order").to("jms:queue:order?messageConverter=#myMessageConverter");

在从 JMS 目的地消耗时,也可以使用自定义消息转换器。

26.6.3. 控制所选映射策略

您可以在端点 URL 上使用 jmsMessageType 选项,以强制所有消息类型。

在以下路由中,我们轮询文件夹中的文件,并将其作为 javax.jms.TextMessage 发送,因为我们强制 JMS producer 端点使用文本消息:

from("file://inbox/order").to("jms:queue:order?jmsMessageType=Text");

您还可以通过使用密钥 CamelJmsMessageType 设置标头来指定要用于每个消息的消息类型。例如:

from("file://inbox/order").setHeader("CamelJmsMessageType", JmsMessageType.Text).to("jms:queue:order");

可能的值在 enumorg.apache.camel.jms.JmsMessageType 中定义。

Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

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

让开源更具包容性

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

關於紅帽

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

© 2024 Red Hat, Inc.