先通过JObject解析JSON再递归生成XElement实现转换。使用Newtonsoft.json解析JSON为JObject,遍历其节点递归构建XElement结构,数组用同名元素表示,最终生成XDocument。需注意JSON与xml数据模型差异,如数组处理、NULL值判断等。

在c#中,没有直接将JSON字符串转换为XML的内置方法,但可以通过中间解析步骤实现。通常的做法是先将JSON解析成对象或动态类型,再将其序列化为XML格式。以下是具体实现方式。
使用 JObject 和递归构建 XML
通过 Newtonsoft.Json 库中的 JObject 解析 JSON,然后递归生成对应的 XElement 结构。
你需要先安装 Newtonsoft.Json 和使用 System.Xml.linq 来操作XML。
示例代码:
using System; using System.Xml.Linq; using Newtonsoft.Json; using Newtonsoft.Json.Linq; public class JsonToXmlConverter { public static XDocument ConvertJsonToXml(string json) { var doc = new XDocument(); var root = new XElement("root"); var obj = JObject.Parse(json); FillXElement(root, obj); doc.Add(root); return doc; } private static void FillXElement(XElement element, JToken token) { foreach (var child in token.Children()) { if (child is JProperty prop) { if (prop.Value is JValue || !(prop.Value.HasValues)) { var childElement = new XElement(prop.Name); childElement.Value = prop.Value.ToString(); element.Add(childElement); } else { var childElement = new XElement(prop.Name); FillXElement(childElement, prop.Value); element.Add(childElement); } } else if (child is JValue val) { element.Value = val.ToString(); } } } }
使用示例:
string json = @"{ 'name': 'Alice', 'age': 30, 'address': { 'city': 'Beijing', 'zip': '100000' } }"; var xmlDoc = JsonToXmlConverter.ConvertJsonToXml(json); Console.WriteLine(xmlDoc.ToString());
输出结果:
Find JSON Path Online
30
Easily find JSON paths within JSON objects using our intuitive Json Path Finder
30
<root> <name>Alice</name> <age>30</age> <address> <city>Beijing</city> <zip>100000</zip> </address> </root>
注意事项与限制
JSON 和 XML 数据模型不完全对等,需注意以下几点:
- JSON 的数组在 XML 中没有直接对应结构,通常用多个同名元素表示
- 属性和文本内容在 XML 中有区别,而 JSON 没有
- 根节点名称可自定义,“root”只是示例
- 空值或 null 的处理需要额外判断
处理 JSON 数组
如果 JSON 包含数组,可以为每个数组项创建一个带索引或统一标签的子元素。
例如:
"items": [ "apple", "banana" ]
可转换为:
<items> <item>apple</item> <item>banana</item> </items>
只需在递归方法中判断 JArray 类型并循环处理即可。
基本上就这些。只要逻辑清晰,这种转换不复杂但容易忽略细节。
