微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 当元素可能是许多可能元素之一时,将XML元素反序列化为Object

在通过pub / sub以XML格式传输消息的本地框架内,我需要能够使用大量消息,但是,所有消息都是作为简单文本接收的,必须反序列化为Xsd工具创建的对象.

消息本身都是从一个基本的MessageType元素/对象派生的,但是如果我基于它反序列化就像这样:

XmlSerializer serializer = new XmlSerializer(typeof(MessageType));
XmlReader reader = XmlReader.Create(new StringReader(rawMessage));
MessageType message = (MessageType)serializer.Deserialize(reader);

我收到一个错误,说实际的元素类型(“UpdateParameter”说)不是预期的.

目前,我能想到的唯一解决方案是使用switch语句:

XmlReader reader = XmlReader.Create(new StringReader(upString));
reader.MovetoContent();
switch (reader.LocalName.ToLower())
{
   case "updateparameter":
      serializer = new XmlSerializer(typeof(UpdateParameter));
      doStuff((UpdateParameter)serializer.Deserialize(xml));
      break;
   case "updateparameterresponse":
      serializer = new XmlSerializer(typeof(UpdateParameterResponse));
      doStuff((UpdateParameterResponse)serializer.Deserialize(xml));
      break;
   case "UpdateStatusResponse":
      serializer = new XmlSerializer(typeof(UpdateStatusResponse));
      doStuff((UpdateStatusResponse)serializer.Deserialize(xml));
      break;
//...etc. Repeat for all possible elements
}

但如果有一个优雅的解决方案,我真的不愿意这样做.我想做的就像是

Type roottype = Type.GetType(reader.localName);// Could work if name is right
serializer = new XmlSerializer(typeof(roottype)); // would work
doStuff((roottype)serializer.Deserialize(xml)); // won't work

但正如评论所指出的那样,它至少不起作用,因为您似乎无法使用类型变量进行转换.此外,当xml元素的localName与Object的本地名称匹配时,上面的方法需要(据我所知)组装限定名称,这是另一个野兽.请注意,理想情况会使doStuff方法过载.

我缺少一个优雅的解决方案吗?或者至少是一个不涉及无限开关语句的解决方案?

解决方法:

在问题How do I use an XmlSerializer to deserialize an object that might be of a base or derived class without knowing the type beforehand?中讨论了相同的问题.

My answer here

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。