c# – 当元素可能是许多可能元素之一时,将XML元素反序列化为Obje
发布时间:2020-12-15 21:14:35 所属栏目:百科 来源:网络整理
导读:在通过pub / sub以 XML格式传输消息的本地框架内,我需要能够使用大量消息,但是,所有消息都是作为简单文本接收的,必须反序列化为Xsd工具创建的对象. 消息本身都是从一个基本的MessageType元素/对象派生的,但是如果我基于它反序列化就像这样: XmlSerializer s
在通过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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |