如何使用 XSLT 将 JSON 转换为 XML?

Posted

技术标签:

【中文标题】如何使用 XSLT 将 JSON 转换为 XML?【英文标题】:How to convert JSON to XML using XSLT? 【发布时间】:2021-07-22 13:27:33 【问题描述】:

我想使用 XSLT 将 JSON 转换为 XML。但无法达到预期的输出。 下面是 JSON 请求:


    "Store": [
        
            "Book": "Cartoons",
            "ID": "ABC"
        
    ]

我尝试过的 XSLT:

 <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:xs="http://www.w3.org/2001/XMLSchema"
    xmlns:math="http://www.w3.org/2005/xpath-functions/math"
    xmlns:xd="http://www.oxygenxml.com/ns/doc/xsl"
    xmlns:emp="http://www.semanticalllc.com/ns/employees#"
    xmlns:h="http://www.w3.org/1999/xhtml"
    xmlns:fn="http://www.w3.org/2005/xpath-functions"
    xmlns:j="http://www.w3.org/2005/xpath-functions"
    exclude-result-prefixes="xs math xd h emp"
    version="3.0"
    expand-text="yes">

<xsl:template match="/">
    <xsl:copy>
        <xsl:apply-templates select="json-to-xml(.)/*"/>
    </xsl:copy>
</xsl:template>

<xsl:template match="*[@key]" xpath-default-namespace="http://www.w3.org/2005/xpath-functions">
    <xsl:element name="@key">
        <xsl:apply-templates/>
    </xsl:element>
</xsl:template>

</xsl:stylesheet>

但我的响应是空的。

【问题讨论】:

我想您的 json 需要在 xml 文件中,或者您将 json 作为根参数传递:请参阅:***.com/q/58113843/3710053 我已经浏览了链接并尝试了。但仍然不适合我。是否可以使用 XSLT 2.0 或 1.0 版本进行转换? 一切皆有可能......“有志者事竟成。”但现在我建议考虑使用 3.0。因此,请将您的 xslt/xml 更新为您的最新尝试。 我已经更新了我尝试使用您提供的链接的 XSLT。同样的问题。不工作。 【参考方案1】:

您需要将 JSON 作为参数传递或从文件中读取,XSLT 的输入要么是 XML,要么您可以从命名模板开始:

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:xs="http://www.w3.org/2001/XMLSchema"
    exclude-result-prefixes="#all"
    version="3.0">
    
  <xsl:param name="json" as="xs:string" expand-text="no">
    "Store": [
        
            "Book": "Cartoons",
            "ID": "ABC"
        
    ]
</xsl:param>

  <xsl:output indent="yes"/>

  <xsl:template match="/" name="xsl:initial-template">
      <xsl:sequence select="json-to-xml($json)"/>
  </xsl:template>
  
</xsl:stylesheet>

https://xsltfiddle.liberty-development.net/93wniTJ

你的样本函数的结果是

<map xmlns="http://www.w3.org/2005/xpath-functions">
   <array key="Store">
      <map>
         <string key="Book">Cartoons</string>
         <string key="ID">ABC</string>
      </map>
   </array>
</map>

当然,您可以通过更多模板运行它以将其转换为不同的格式。

【讨论】:

但是传入的 JSON 请求值会发生变化。 您可以在每次运行转换之前更改任何全局参数。 示例是 XSLT 3,我不知道是否或如何将它集成到 IBM 数据能力中,如果这是您正在使用的环境。【参考方案2】:

模式 match="/" 匹配文档节点(XML 树的根)。如果输入是 JSON,它将与您的输入不匹配。

XSLT 3.0 实际上并不擅长使用模板规则处理 JSON:它可以做到,但不是很方便。使用函数通常更方便。您可以将 JSON 输入作为 xsl:param 的值提供,并在 xsl:initial-template 的代码中对其进行处理;或者,如果您感觉更有野心,您实际上可以通过调用将 JSON 输入作为参数的公共 xsl:function 来启动 XSLT 处理。

样式表中传统的match="/" 条目仅适用于使用 XSLT 处理 XML 输入文档的传统方式。

【讨论】:

嗨迈克尔,我发现在不使用 Convert-query-params 的情况下将 json 转换为 Jsonx 有困难。你能帮我如何使用 gatewayscript 将 Json 转换为 Jsonx 或 XML。在使用 Gatewayscript 时,我浏览了几个 IBM 论坛并遇到了错误。 这需要一个单独的问题——而且可能需要另一个人来回答,因为我对 Json 或 Gatewayscript 一无所知。

以上是关于如何使用 XSLT 将 JSON 转换为 XML?的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 xslt 将嵌套的 Json 对象转换为 xml

如何停止 xslt3.0 的 xml-to-json() 函数将数字转换为指数表示法

使用 XSLT 将 XML 转换为 JSON

使用自定义 XSLT 将 XML 转换为 JSON 会丢失花括号

WSO2 Enterprise Integrator 6.6.0 使用 XSLT 将 XML 响应转换为 Json

xslt 3.0 json-to-xml 和 xml-to-json 转换