xmlSerializer可将C#对象序列化为XML字符串,要求类及成员为public、含public无参构造函数、属性需有get/set访问器,支持集合与嵌套对象,可通过XmlWriterSettings控制格式。

用 XmlSerializer 类就能把 C# 对象转成 XML 字符串,关键是对象要满足可序列化要求,比如有公共无参构造函数、公共属性、不能是匿名类型或指针类型。
确保类支持 XML 序列化
被序列化的类需要是 public 的,所有要导出的字段或属性也得是 public,并且推荐用属性(get/set)而不是字段。如果不想某个属性参与序列化,加 [XmlIgnore] 特性。
基础序列化代码示例
用 StringWriter + XmlSerializer 把对象写入字符串:
var person = new Person { Name = "张三", Age = 28 }; var serializer = new XmlSerializer(typeof(Person)); using var writer = new StringWriter(); serializer.Serialize(writer, person); string xml = writer.ToString(); // 得到 XML 字符串
控制 XML 输出格式(可选)
默认输出紧凑无缩进。如需缩进、换行、指定编码,可用 XmlWriter 配合 XmlWriterSettings:
本文档主要讲述的是JSON.NET 简单的使用;JSON.NET使用来将.NET中的对象转换为JSON字符串(序列化),或者将JSON字符串转换为.NET中已有类型的对象(反序列化?)。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看
0 - 设置
Indent = true让 XML 更易读 - 设置
Encoding = Encoding.UTF8明确编码(避免 bom 或乱码) - 用
XmlWriter.Create(...)创建带配置的写入器
示例:
var settings = new XmlWriterSettings { Indent = true, Encoding = Encoding.UTF8 }; using var writer = XmlWriter.Create(new StringWriter(), settings); serializer.Serialize(writer, person);
处理集合和嵌套对象
XmlSerializer 原生支持数组、List<t></t>、Dictionary<k></k>(但字典需额外处理,建议用 List
- 集合属性建议用
List<t></t>,别用IEnumerable<t></t>(接口无法实例化) - 若想自定义集合元素标签名,加
[XmlElement("Item")] - 根节点名默认是类名,可用
[XmlRoot("People")]修改
基本上就这些。不复杂但容易忽略无参构造和属性可访问性。