搜索

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

download PDF

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

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

正文类型JMS Message注释

字符串

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 Message正文类型

javax.jms.TextMessage

字符串

javax.jms.BytesMessage

byte[]

javax.jms.MapMessage

Map<String, Object>

javax.jms.ObjectMessage

对象

31.6.1. 禁用自动映射 JMS 消息

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

31.6.2. 使用自定义 MessageConverter

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

例如,在下面的路由中,在向 JMS order 队列发送消息时,使用自定义消息转换器:

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

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

31.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.