xmlSerializer序列化时去掉XML声明的关键是使用XmlWriterSettings设置OmitXmlDeclaration=true,通过XmlWriter控制输出而非字符串替换;注意StringWriter默认UTF-16编码,推荐Memorystream配合UTF-8避免编码问题。

用 XmlSerializer 序列化对象时,默认会生成带 XML 声明(如 <?xml version="1.0" encoding="utf-8"?>)的字符串。要去掉它,关键在于**控制序列化输出的 XmlWriter 设置**,而不是修改序列化器本身。
使用 XmlWriterSettings 禁用 XML 声明
创建 XmlWriter 时传入一个配置好的 XmlWriterSettings,把 OmitXmlDeclaration 设为 true:
- 新建
StringWriter接收输出 - 新建
XmlWriterSettings,设OmitXmlDeclaration = true - 用该设置创建
XmlWriter,再传给XmlSerializer.Serialize()
示例代码:
var obj = new Person { Name = "张三", Age = 30 }; var serializer = new XmlSerializer(typeof(Person)); var settings = new XmlWriterSettings { OmitXmlDeclaration = true, Indent = true // 可选:美化格式 }; using var sw = new StringWriter(); using var writer = XmlWriter.Create(sw, settings); serializer.Serialize(writer, obj); string xmlWithoutDecl = sw.ToString(); // <Person><Name>张三</Name><Age>30</Age></Person>
注意编码一致性
如果后续要写入文件或网络流,StringWriter 默认用 UTF-16,而多数场景期望 UTF-8。此时建议直接用 MemoryStream + UTF8Encoding 配合 XmlWriter,避免字符串编码隐式转换问题。
不推荐用字符串替换方式
比如先序列化再用 .Replace("<?xml ... ?>", "") —— 容易出错:
• 声明内容可能因环境不同而变化(如 encoding 不同)
• 若对象里字段值恰好含类似文本,会被误删
• 失去 XML 写入器本身的格式控制能力(如缩进、命名空间处理)
基本上就这些。核心就是交给 XmlWriter 控制输出行为,而不是事后处理字符串。