先通过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());
输出结果:
Alice 30 Beijing 100000
注意事项与限制
JSON 和 XML 数据模型不完全对等,需注意以下几点:JSON 的数组在 XML 中没有直接对应结构,通常用多个同名元素表示 属性和文本内容在 XML 中有区别,而 JSON 没有 根节点名称可自定义,“root”只是示例 空值或 null 的处理需要额外判断
处理 JSON 数组
如果 JSON 包含数组,可以为每个数组项创建一个带索引或统一标签的子元素。
例如:
"items": [ "apple", "banana" ]
可转换为:
apple banana
只需在递归方法中判断 JArray 类型并循环处理即可。
基本上就这些。只要逻辑清晰,这种转换不复杂但容易忽略细节。
以上就是C# 如何将JSON字符串转换为xml的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1441048.html
微信扫一扫
支付宝扫一扫