第 72 章 JacksonXML
Jackson XML 是一个数据格式,它使用带有 XMLMapper 扩展的 Jackson 库,将一个 XML 有效负载 unmarshal 到一个 Java 对象,或将 Java 对象 marshal 到一个 XML 有效负载。注意:如果您熟悉 Jackson,这个 XML 数据格式的行为方式与其 JSON 对应部分相同,因此可用于注解用于 JSON 序列化/反序列化的类。
此扩展还模拟 JAXB 的"代码第一个"方法。
此数据格式依赖于 Woodstox (特别是用户打印等功能),这是一个快速高效的 XML 处理器。
from("activemq:My.Queue"). unmarshal().jacksonxml(). to("mqseries:Another.Queue");
72.1. jacksonxml 选项
JacksonXML 数据格式支持 15 个选项,如下所列。
Name | 默认值 | Java 类型 | 描述 |
---|---|---|---|
xmlMapper |
| 查找并使用给定 ID 的现有 XmlMapper。 | |
prettyPrint | false |
| 以格式方式启用用户友善打印输出。默认为 false。 |
unmarshalType |
| 取消总结时要使用的 java 类型的类名称。 | |
jsonView |
| 将 POJO 写入 JSON 时,您可能希望从 JSON 输出中排除某些字段。通过 Jackson,您可以使用 JSON 视图来实现这一目的。这个选项是引用具有 JsonView 注解的类。 | |
Include |
| 如果要将 pojo 重命名为 JSON,并且 pojo 具有一些带有 null 值的字段。如果您想要跳过这些 null 值,您可以将这个选项设置为 NON_NULL。 | |
allowJmsType |
| 用于 JMS 用户,允许 JMS spec 中的 JMSType 标头指定用于 unmarshal 的 FQN 类名称。 | |
collectionType |
| 指的是要在 registry 中查找的自定义集合类型。应很少使用这个选项,但允许使用与 java.util.Collection 不同的集合类型作为默认值。 | |
useList |
| 要取消选择映射列表或 Pojo 列表。 | |
enableJaxbAnnotationModule |
| 使用 jackson 时是否启用 JAXB 注解模块。启用后,Jackson 可以使用 JAXB 注解。 | |
moduleClassNames |
| 使用自定义 Jackson 模块 com.fasterxml.jackson.databind.Module 指定为带有 FQN 类名称的 String。可以使用逗号分隔多个类。 | |
moduleRefs |
| 使用 Camel registry 中引用的自定义 Jackson 模块。可以使用逗号分隔多个模块。 | |
enableFeatures |
| 在 Jackson com.fasterxml.jackson.databind.ObjectMapper 上启用的功能集合。功能应该是与 com.fasterxml.jackson.databind.SerializationFeature、com.fasterxml.jackson.databind.DeserializationFeature 或 com.fasterxml.jackson.databind.MapperFeature 多功能中的 enum 匹配的名称。 | |
disableFeatures |
| 在 Jackson com.fasterxml.jackson.databind.ObjectMapper 上禁用的功能集合。功能应该是与 com.fasterxml.jackson.databind.SerializationFeature、com.fasterxml.jackson.databind.DeserializationFeature 或 com.fasterxml.jackson.databind.MapperFeature 多功能中的 enum 匹配的名称。 | |
allowUnmarshallType |
| 如果启用,则允许 Jackson 在 unmarshalling 期间尝试使用 CamelJacksonUnmarshalType 标头。这只在需要使用时才启用。 | |
contentTypeHeader |
| 数据格式是否应使用数据格式的类型设置 Content-Type 标头。例如,用于数据格式的 application/xml 例如,marshalling 到 XML,对于数据格式为 JSON,application/json 用于数据格式。 |
72.1.1. 在 Spring DSL 中使用 Jackson XML
当在 Spring DSL 中使用 Data Format 时,您需要首先声明数据格式。这是在 DataFormats XML 标签中完成的。
<dataFormats> <!-- here we define a Xml data format with the id jack and that it should use the TestPojo as the class type when doing unmarshal. The unmarshalType is optional, if not provided Camel will use a Map as the type --> <jacksonxml id="jack" unmarshalType="org.apache.camel.component.jacksonxml.TestPojo"/> </dataFormats>
然后您可以在路由中引用此 id:
<route> <from uri="direct:back"/> <unmarshal><custom ref="jack"/></unmarshal> <to uri="mock:reverse"/> </route>
72.1.2. 从 marshalling 中排除 POJO 字段
当将 POJO 写入 XML 时,您可能希望从 XML 输出中排除某些字段。通过 Jackson,您可以使用 JSON 视图 来实现这一目的。首先创建一个或多个标记类。
使用带有 @JsonView
注释的标记类,使其包含/排除某些字段。该注解也适用于 getters。
最后,使用 Camel JacksonXMLDataFormat
将上述 POJO 写入 XML。
请注意,生成的 XML 中缺少 weight 字段:
<pojo age="30" weight="70"/>