53.2. 选项
JAXB dataformat 支持 20 个选项,如下所列。
| Name | 默认值 | Java 类型 | 描述 |
|---|---|---|---|
| contextPath |
| 您的 JAXB 类所在的 必需 软件包名称。 | |
| contextPathIsClassName |
|
| 这可以设为 true,以标记 contextPath 指向 classname 而不是软件包名称。 |
| schema |
| 对现有模式进行验证。您可以使用前缀 classpath:、file: 或 http: 指定如何解析资源。您可以使用 ',' 字符分隔多个架构文件。 | |
| schemaSeverityLevel |
|
| 设置在针对 schema 验证时要使用的模式严重性级别。此级别决定了触发 JAXB 停止继续解析的最低严重性错误。默认值为 0 (警告)意味着任何错误(警告、错误或严重错误)将触发 JAXB 停止。有三个级别有以下三个级别:0=warning, 1=error, 2=fatal 错误。 Enum 值:
|
| 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 |
|
| 数据格式是否应该使用数据格式的类型设置 Content-Type 标头。例如,用于数据格式的 application/xml 放入 XML 或用于数据格式的 application/json,以转至 JSON。 |
| accessExternalSchemaProtocols |
|
| 仅在启用了 schema 验证时使用。限制访问由 schemaLocation 属性、Import 和 Include 元素为外部引用指定的协议。协议示例包括 file, http, jar:file. false 或 none 以拒绝对外部引用的所有访问;特定协议(如 file)仅授予协议的权限;关键字 all 以授予所有协议的权限。 |