第 169 章 JAXB DataFormat
从 Camel 版本 1.0 开始提供
JAXB 是一种 Data Format,它使用 JAXB2 XML marshalling 标准,包含在 Java 6 中,将 XML 有效负载 unmarshal 到 Java 对象,或将 Java 对象嵌套到 XML 有效负载中。
169.1. 选项
JAXB dataformat 支持 18 个选项,如下所列。
Name | 默认值 | Java 类型 | 描述 |
---|---|---|---|
contextPath |
| 您的 JAXB 类所在的软件包名称。 | |
schema |
| 对现有模式进行验证。您可以使用前缀 classpath:、file: 或 http: 指定资源应如何解析。您可以使用 ',' 字符分隔多个架构文件。 | |
schemaSeverityLevel |
|
| 设置在针对 schema 验证时要使用的模式严重性级别。此级别决定了触发 JAXB 停止继续解析的最低严重性错误。默认值为 0 (警告)意味着任何错误(警告、错误或严重错误)将触发 JAXB 停止。有三个级别有以下三个级别:0=warning, 1=error, 2=fatal 错误。 |
prettyPrint |
|
| 要启用用户的打印输出,请执行以下操作:默认为 false。 |
objectFactory |
|
| 是否允许使用 ObjectFactory 类在 marshalling 期间创建 POJO 类。这只适用于没有使用 JAXB 注解并提供 jaxb.index 描述符文件的 POJO 类。 |
ignoreJAXBElement |
|
| 是否要在非常特殊用例中忽略 JAXBElement 元素 - 只需要设置为 false。 |
mustBeJAXBElement |
|
| marhsalling 必须是带有 JAXB 注释的 java 对象。如果不是,则失败。这个选项可以设置为 false 以宽松,例如当数据已采用 XML 格式时。 |
filterNonXmlChars |
|
| 要忽略非 xml characheters,并使用一个空空间替换它们。 |
编码 |
| overrule 并使用特定的编码 | |
片段 |
|
| 打开 marshalling XML 片段树。默认情况下,JAXB 会查找给定类上的 XmlRootElement 注释,以针对整个 XML 树操作。这很有用,但并不总是 - 有时生成的代码没有 XmlRootElement 注解,有时您需要 unmarshall 仅是树的一部分。在这种情况下,您可以使用部分 unmarshalling。要启用此功能,您需要设置属性 partClass。Camel 会将此类传递给 JAXB 的 unmarshaler。 |
partClass |
| 用于片段解析的类名称。请参阅片段选项的详情。 | |
partNamespace |
| 用于片段解析的 XML 命名空间。请参阅片段选项的详情。 | |
namespacePrefixRef |
| 使用 JAXB 或 SOAP 进行 marshalling 时,JAXB 实施将自动分配命名空间前缀,如 ns2、ns3、ns4 等。要控制此映射,Camel 允许您引用包含所需映射的映射。 | |
xmlStreamWriterWrapper |
| 使用自定义 xml 流写入器。 | |
schemaLocation |
| 定义模式的位置 | |
noNamespaceSchemaLocation |
| 定义无命名空间模式的位置 | |
jaxbProviderProperties |
| 指的是包含用于 JAXB marshaller 的自定义 JAXB 提供程序属性的 registry 中的自定义 java.util.Map。 | |
contentTypeHeader |
|
| 如果数据格式可以这样做,则数据格式是否应使用 data 格式的类型设置 Content-Type 标头。例如,用于数据格式的 application/xml 放入 XML 或用于数据格式的 application/json,如 JSon 等。 |