我正在尝试使用两个命名空间反序列化 XML,就像这样
<records xmlns="http://www.foo.com/xml/records/1.1">
<record xmlns="http://www.foo.com/xml/record/1.1">
有时是旧版本
<records xmlns="http://www.foo.com/xml/records/1.1">
<record xmlns="http://www.foo.com/xml/record/1.0">
我的 Records.cs 类(class)有
[XmlRoot(ElementName = "records", Namespace = "http://www.foo.com/xml/records/1.1")]
public class Records
{
[System.Xml.Serialization.XmlElementAttribute("record")]
public List<Record> Records { get; set; }
}
我希望记录列表能够包含 1.0 版或 1.1 版记录
/// <remarks/>
[XmlRoot(IsNullable = false, ElementName = "record", Namespace = "http://www.foo.com/xml/record/1.0")]
public partial class Record
{
/// <remarks/>
public Record()
{
}
}
/// <remarks/>
[XmlRoot(IsNullable = false, ElementName = "record", Namespace = "http://www.foo.com/xml/record/1.1")]
public partial class Record11 : Record
{
/// <remarks/>
public Record11()
{
}
}
所以我认为对记录进行子类化会起作用。
反序列化时出现反射异常,异常将我指向 XmlChoiceIdentifier 属性。但是,这似乎与枚举有关。
任何人都知道如何做我想做的事情(支持反序列化同一架构的多个版本?)
谢谢。
最佳答案
[XmlRoot]
两者的属性 Record
和 Record11
在您的示例中将被忽略。只有当元素是树中的根时它们才有意义。你更需要做的是:
[XmlRoot(ElementName = "records",
Namespace = "http://www.foo.com/xml/records/1.1")]
public class Records
{
[XmlElement(Type = typeof(Record),
ElementName = "record",
Namespace = "http://www.foo.com/xml/records/1.0")]
[XmlElement(Type = typeof(Record11),
ElementName = "record",
Namespace = "http://www.foo.com/xml/records/1.1")]
public List<Record> Records { get; set; }
}
关于c# - 使用 .NET XmlSerializer 反序列化时使用多个命名空间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1435260/