将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 { } }