搜索

第 78 章 JAXB

download PDF

JAXB 是一种数据格式,它使用 JAXB2 XML marshalling 标准,该标准包含在 Java 6 中,将 XML 有效负载 unmarshal Java 对象 unmarshal Java 对象到一个 XML 有效负载中。

78.1. 选项

JAXB 数据格式支持 19 个选项,如下所列。

Name默认值Java 类型描述

contextPath

 

字符串

您的 JAXB 类所在的所需软件包名称。

contextPathIsClassName

 

布尔值

这可以设置为 true 来标记 contextPath 引用 classname 而不是软件包名称。

schema

 

字符串

针对现有模式进行验证:您可以使用前缀 classpath:, file: 或 http: 指定资源应该如何解析。您可以使用 ',' 字符分隔多个架构文件。

schemaSeverityLevel

 

Enum

设置在针对模式验证时要使用的模式严重性级别。此级别决定了触发 JAXB 停止继续解析的最低严重性错误。默认值为 0 (warning)表示任何错误(警告、错误或严重错误)将触发 JAXB 以停止。有三个级别: 0=warning, 1=error, 2=fatal 错误。

Enum 值:

  • 0
  • 1
  • 2

prettyPrint

 

布尔值

以格式方式启用用户友善打印输出。默认为 false。

ObjectFactory

 

布尔值

是否允许使用 ObjectFactory 类在 marshalling 期间创建 POJO 类。这只适用于尚未使用 JAXB 注解并提供 jaxb.index 描述符文件的 POJO 类。

ignoreHQBElement

 

布尔值

是否忽略 JAXBElement 元素 - 只需要在非常特殊用例中将 JAXBElement 元素设置为 false。

mustBeöBElement

 

布尔值

marhsalling 必须是带有 JAXB 注解的 java 对象。如果没有,则会失败。这个选项可以设置为 false 以放松,例如当数据已采用 XML 格式时。

filterNonXmlChars

 

布尔值

要忽略非 xml characheters,并使用空空间替换它们。

编码

 

字符串

要覆盖rule 并使用特定的编码。

片段

 

布尔值

打开 marshalling XML 片段树。默认情况下,B 在给定类上查找 XmlRootElement 注释,以便在整个 XML 树上运行。这很有用,但并不总是 - 有时生成的代码没有 XmlRootElement 注解,有时您只需要对树的一部分进行 unmarshall 部分。在这种情况下,您可以使用部分 unmarshalling。要启用此功能,您需要设置属性 partClass。Camel 会将此类传递到 JAXB 的 unmarshaler。

partClass

 

字符串

用于片段解析的类名称。请参阅 slice 选项的详情。

partNamespace

 

字符串

用于片段解析的 XML 命名空间。请参阅 slice 选项的详情。

namespacePrefixRef

 

字符串

当使用 JAXB 或 SOAP 进行 marshalling 时,JAXB 实施将自动分配命名空间前缀,如 ns2、ns3、ns4 等。要控制此映射,Camel 允许您引用包含所需映射的映射。

xmlStreamWriterWrapper

 

字符串

使用自定义 xml 流写入器。

schemaLocation

 

字符串

定义模式的位置。

noNamespaceSchemaLocation

 

字符串

定义无命名空间模式的位置。

jaxbProviderProperties

 

字符串

指的是一个自定义 java.util.Map,用于在包含 JAXB marshaller 的自定义 JAXB 提供程序属性的 registry 中查找。

contentTypeHeader

 

布尔值

数据格式是否应使用数据格式的类型设置 Content-Type 标头。例如,用于数据格式的 application/xml 例如,marshalling 到 XML,对于数据格式为 JSON,application/json 用于数据格式。

Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

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

让开源更具包容性

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

關於紅帽

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

© 2024 Red Hat, Inc.