我有一个对象,我们序列化和反序列化。在序列化对象时,我们动态添加命名空间,这在类定义中不存在作为属性。我创建了一个小例子来重复这个问题:
我有一个名为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();
}
}
任何帮助将不胜感激
答案 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>
,那么是:那将无效(但是:那不是代码在问题显示)