将XmlSerializer与私有和公共const属性一起使用

让XmlSerializer同时序列化类或结构的私有和“公共const”属性的最简单方法是什么? 对我来说,输出的并不仅仅是公开的。 将其设为私有或添加const会导致值无法序列化。

XmlSerializer仅查看公共字段和属性。 如果您需要更多控制,可以实现IXmlSerializable并序列化您想要的任何内容。 当然,序列化常量没有太大意义,因为您无法反序列化为常量。

即使无法序列化私有属性,也可以使用内部setter序列化属性,如下所示:

 public string Foo { get; internal set; } 

为此,您需要使用sgen.exe预生成序列化程序集,并将此程序集声明为friend:

 [assembly:InternalsVisibleTo("MyAssembly.XmlSerializers")] 

查看.NET 3.0中引入的DataContractSerializer。 它还使用XML格式,在许多方面,它比XmlSerializer更好,包括处理私有数据。 有关完整比较,请参阅http://www.danrigsby.com/blog/index.php/2008/03/07/xmlserializer-vs-datacontractserializer-serialization-in-wcf/ 。

如果您只有.NET 2.0,那么BinarySerializer可以处理私有数据,但当然它是二进制格式。

考虑const成员是没有意义的,因为它们不是每个实例; 但是如果你只是指非公共实例成员:考虑DataContractSerializer (.NET 3.0) – 这类似于XmlSerializer ,但可以序列化非公共属性(尽管它是“选择加入”)。

请看这里了解更多 。

使用Newtonsoft.Json的另一个解决方案:

  var json = Newtonsoft.Json.JsonConvert.SerializeObject(new { root = result }); var xml = (XmlDocument)Newtonsoft.Json.JsonConvert.DeserializeXmlNode(json); 

当然,不幸的是这个绕道而行。

这是我将不可变值放在将序列化为XML的属性中的解决方案:

 [XmlElement] public string format { get { return "Acme Order Detail XML v3.4.5"; } set { } }