由于在序列化上动态添加名称空间而导致反序列化失败

时间:2013-10-28 11:11:54

标签: c# xml serialization xml-serialization

我有一个对象,我们序列化和反序列化。在序列化对象时,我们动态添加命名空间,这在类定义中不存在作为属性。我创建了一个小例子来重复这个问题:

我有一个名为Person的课程:

[XmlRoot("person")]
public class Person
{
    [XmlIgnore]
    public DateTime? dob { get; set; }

    [XmlAttribute("dobs")]
    public DateTime dobser { get{return dob.Value;} set{dob=value;} }

    public bool ShouldSerializedobser()
    {
        return dob.HasValue;
    }

    [XmlAttribute("name")]
    public string Name { get; set; }

    public bool ShouldSerializeName()
    {
        return !string.IsNullOrWhiteSpace(Name);
    }

    public int? Age { get; set; }

}

这里代码序列化和反序列化,

public class Program
{
    static void Main(string[] args)
    {
         var person = new Person();
         person.Age = 12;
         StringBuilder sb = new StringBuilder();
         StringWriter sw = new StringWriter(sb);
         //add namespace
         XmlSerializerNamespaces namespaces = new XmlSerializerNamespaces();
         namespaces.Add("ns1", "http://www.microsoft.com/schema/ml/v1");
         XmlSerializer xs = new XmlSerializer(typeof(Person));
         xs.Serialize(sw, person,namespaces);

         // try to deserialize, it fails. It is working If I don't add namespace
         xs.Deserialize(GenerateStreamFromString(sb.ToString()));

         Console.WriteLine(sb.ToString());
         Console.Read();
    }
 }

任何帮助将不胜感激

1 个答案:

答案 0 :(得分:2)

发布的守则对我来说很好;我不得不发明自己的GenerateStreamFromString,但是:没有问题。您确定问题不是unicode / BOM问题吗?

有关信息,我发明的方法是:

private static Stream GenerateStreamFromString(string value)
{
    return new MemoryStream(Encoding.Unicode.GetBytes(value));
}

虽然实际上我更喜欢:

private static XmlReader GenerateReaderFromString(string value)
{
    return XmlReader.Create(new StringReader(value));
}

(更直接;开销更少)

最后一点:您知道<person> 该命名空间中的,对吗?您的代码只声明了一个从未使用过的别名。如果实际代码试图反序列化引用的命名空间中的<person> ,那么是:那将无效(但是:那不是代码在问题显示)