第 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"/>
Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

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

让开源更具包容性

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

關於紅帽

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

© 2024 Red Hat, Inc.