可直接用XDocument.Load(Stream)加载流,需确保stream.CanRead为true且Position为0;推荐using块管理资源;无BOM或XML声明时宜用XmlReader显式指定编码;byte[]或string可转MemoryStream加载;注意捕获XmlException、IOException等异常。
可以直接使用 XDocument.Load() 方法,传入 Stream 对象即可。注意确保流位置在开头(stream.Position == 0),否则可能读取为空或报错。
这是最直接的方式,适用于内存流、文件流、网络响应流等可读流:
stream.CanRead == true)stream.Seek(0, SeekOrigin.Begin)
示例:
using (var stream = File.OpenRead("data.xml"))
{
var doc = XDocument.Load(stream);
// 使用 doc...
}XDocument.Load(Stream) 默认依赖流的字节顺序标记(BOM)或 XML 声明(如 )推断编码。若流无 BOM 且声明缺失,可能解析出错。
XmlReader 显式指定编码(如 UTF-8)再传给 XDocument.Load()
示例(强制 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)) → 适合字符串场景XML 解析失败常见于格式错误、编码不匹配或流中断。建议捕获以下异常:
XmlException:XML 结构或声明非法IOException:流读取失败(如网络断开、文件被占用)ArgumentNullException:传入 null 流生产环境应记录原始流前若干字节(如 stream.Take(256).ToArray()),便于定位问题。