可直接用XDocument.Load(Stream)加载流,需确保stream.CanRead为true且Position为0;推荐using块管理资源;无BOM或XML声明时宜用XmlReader显式指定编码;byte[]或string可转MemoryStream加载;注意捕获XmlException、IOException等异常。

可以直接使用 XDocument.Load() 方法,传入 Stream 对象即可。注意确保流位置在开头(stream.Position == 0),否则可能读取为空或报错。
使用 XDocument.Load(Stream) 加载
这是最直接的方式,适用于内存流、文件流、网络响应流等可读流:
- 流必须支持读取(
stream.CanRead == true) - 推荐在 using 块中使用,确保流被正确释放
- 若流已读到末尾(Position == Length),需先调用
stream.Seek(0, SeekOrigin.Begin)
示例:
using (var stream = File.OpenRead("data.xml"))
{
var doc = XDocument.Load(stream);
// 使用 doc...
}处理 UTF-8 BOM 或编码问题
XDocument.Load(Stream) 默认依赖流的字节顺序标记(BOM)或 XML 声明(如 )推断编码。若流无 BOM 且声明缺失,可能解析出错。
- 稳妥做法:用
XmlReader显式指定编码(如 UTF-8)再传给XDocument.Load() - 尤其适用于从网络响应、Base64 解码后字节数组创建的流
示例(强制 UTF-8):
var settings = new XmlReaderSettings { DtdProcessing = DtdProcessing.Ignore };
using (var reader = XmlReader.Create(stream, settings))
{
var doc = XDocument.Load(reader);
}从字节数组或字符串快速加载
如果已有 byte[] 或 string,可转为 MemoryStream 再加载:
-
new MemoryStream(bytes)→ 直接用于XDocument.Load() -
new MemoryStream(Encoding.UTF8.GetBytes(xmlString))→ 适合字符串场景 - 注意:MemoryStream 构造后 Position 默认为 0,无需额外 Seek
异常处理建议
XML 解析失败常见于格式错误、编码不匹配或流中断。建议捕获以下异常:
-
XmlException:XML 结构或声明非法 -
IOException:流读取失败(如网络断开、文件被占用) -
ArgumentNullException:传入 null 流
生产环境应记录原始流前若干字节(如 stream.Take(256).ToArray()),便于定位问题。










