先通过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());
输出结果:
本文档主要讲述的是JSON.NET 简单的使用;JSON.NET使用来将.NET中的对象转换为JSON字符串(序列化),或者将JSON字符串转换为.NET中已有类型的对象(反序列化?)。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看
Alice 30 Beijing 100000
注意事项与限制
JSON 和 XML 数据模型不完全对等,需注意以下几点:- JSON 的数组在 XML 中没有直接对应结构,通常用多个同名元素表示
- 属性和文本内容在 XML 中有区别,而 JSON 没有
- 根节点名称可自定义,“root”只是示例
- 空值或 null 的处理需要额外判断
处理 JSON 数组
如果 JSON 包含数组,可以为每个数组项创建一个带索引或统一标签的子元素。例如:
"items": [ "apple", "banana" ]
可转换为:
- apple
- banana
只需在递归方法中判断 JArray 类型并循环处理即可。









