将 xml 转换为 json 的 WSO2 ESB 问题

Posted

技术标签:

【中文标题】将 xml 转换为 json 的 WSO2 ESB 问题【英文标题】:WSO2 ESB problem with convert xml to json 【发布时间】:2020-05-14 09:39:59 【问题描述】:

我使用属性调解器将 xml 转换为 json <property name="messageType" scope="axis2" type="STRING" value="application/json"/>

这是可行的,但是当 xml 消息包含像 50103015080000000550022052 这样的数字时,在转换为 json 后,该值将变为 5.010301508E25。

我需要有原始值。知道怎么做吗?

提前致谢。

【问题讨论】:

【参考方案1】:

这是由于 wso2 ESB 服务器提供的自动原语特性所致。在这里,当从 XML 发生转换时,会自动识别 JSON 原始类型。因此,数字 50103015080000000550022052 被识别为数字并以科学计数法表示。

在 EI 服务器 [1] 中默认启用自动原语功能。

我们可以通过在以下位置配置 synapse.commons.json.output.autoPrimitive=false 来全局禁用自动图元功能。这将应用于全局的所有原始数据类型。

[EI_HOME]/conf/synapse.properties

此外,我们还可以通过提供正则表达式模式仅对一组数据禁用自动原始功能。如果您只想对上述数据集禁用自动原始功能,请在 [EI_HOME]/conf/synapse.properties 文件中配置以下内容。

synapse.commons.json.output.disableAutoPrimitive.regex=^-?(0|[1-9][0-9]*)(.[0-9]+)?$ 以上配置完成后请重启服务器。

[1]-https://docs.wso2.com/display/EI650/Working+with+JSON+Message+Payloads

【讨论】:

以上是关于将 xml 转换为 json 的 WSO2 ESB 问题的主要内容,如果未能解决你的问题,请参考以下文章

WSO2:wso2中的xml到json数据映射esb:json消息包含在soap信封中

WSO2:将CSV消息转换为json wso2 esb。在prolog中出现意外字符'“'(代码34)失败;预期'

WSO2 ESB 5.0.0 一些组件的使用教程

WSO2 ESB 5.0.0 一些组件的使用教程

为什么JSON路径无效为WSO2 ESB 5.0的JSON请求

WSO2 ESB PayloadFactory 中介器中的 JSON 格式