0

嘿,每个人都有一个关于在 C# .net 4 MVC 3 中解析一些 XML 的问题。

我有一个从 java 应用程序序列化为 XML 的 Map (HashMap)。

我需要将其解析为 dotnet 端的对象,但似乎无法弄清楚。在我的研究中,我发现您无法序列化为Dictionary<string, string>.

其他人提出了一个public struct KeyValuePair<K, V>,但似乎没有用。

还尝试了一个[XmlArray("mapConfig")]

先决条件之一是我们必须使用System.Xml.Serialization,因为我们有一个抽象的信使类,如果我不是绝对必须的话,我想避免改变它。

如果必须,我可能会更改 Java 对象,如果这会使这更容易,但如果可能的话,我宁愿使用已经存在的对象。如果它有助于 Java 层使用 Xstream。

这是从 Java 发送的一大段 XML

<ConfigurationMap>
    <mapConfig class="hashtable">
      <entry>
        <string>Key1</string>
        <string>Value1</string>
      </entry>
      <entry>
        <string>Key2</string>
        <string>Value2</string>
      </entry>
      <entry>
        <string>Key3</string>
        <string>Value3</string>
      </entry>
      <entry>
        <string>Key4</string>
        <string>Value4</string>
      </entry>
    </mapConfig>
</ConfigurationMap>

谢谢,如果您需要更多信息,请告诉我。期待答案。

- 更新 -

我认为这很明显,但我应该提到 XML 将以字符串的形式返回到我提到的抽象消息中。当前方法使用:

XmlDocument doc = new XmlDocument();
doc.LoadXml(this.ResponseXml);
XmlElement main = doc.DocumentElement;

XmlElement cse = util.getElementsFirstChild(main, "MessagePayload");
XmlElement ccs = util.getElementsFirstChild(cse, "ReturnedObjectNameHERE");

System.Xml然后我们使用模型上的属性反序列化片段。

这是我们使用一些通用属性的模型的简单示例:

[XmlRoot("list")]
public class SearchResults : List<CSearchResult>
{
    public SearchResults() { }
}

[XmlRoot("SearchResult")]
public class SearchResult
{
    [XmlElement("Id")]
    public string OrgUnitId { get; set; }

    [XmlElement("Type")]
    public Type Type { get; set; }

    [XmlElement("Name")]
    public string Name { get; set; }

    [XmlElement("Description")]
    public string Description { get; set; }
}

-- 更新 2 -- 我能够使用下面的这个模型类获得一些不错的模型绑定

[XmlRoot("ConfigurationMap")]
public class ConfigurationMap
{
    [XmlElement("mapConfig")]
    public MapConfig mapConfig { get; set; }

}

[XmlRoot("mapConfig")]
public class MapConfig
{
    [XmlArray("entry")]
    public List<string> entry { get; set; }
}

唯一的问题是 Object 属性 mapconfig 只是将所有条目聚集在一个列表中,这对于模型来说是有意义的。

试图弄乱数组类型,看看我是否能得到更好的结果。看着制作MapConfig一个数组Entry。我可以保留Entry一个列表或创建Entry一个数组,以便对象结构变为:

MapConfig: [[key1, value1], [key2, value2], [key3, value3], [key4, value4],]

试图确定这是否是一个更好的结构。

在我解决这个问题时,任何关于此的建议都会有所帮助。

谢谢

4

2 回答 2

2

你可以创建一个类来序列化成......所以在xml上运行xsd.exe......

C:\>xsd test.xml
Microsoft (R) Xml Schemas/DataTypes support utility
[Microsoft (R) .NET Framework, Version 4.0.30319.17929]
Copyright (C) Microsoft Corporation. All rights reserved.
Writing file 'C:\test.xsd'.

C:\>xsd test.xsd /classes
Microsoft (R) Xml Schemas/DataTypes support utility
[Microsoft (R) .NET Framework, Version 4.0.30319.17929]
Copyright (C) Microsoft Corporation. All rights reserved.
Writing file 'C:\test.cs'.

然后只需使用简单的 c# XmlSerializer ...

NewClassName object = xml.DeSerializeStringToObject<NewClassName>();

下面的助手类

public static class XmlSerializerHelper
{
    public static T DeSerializeStringToObject<T>(this string sxml)
    {
        using (XmlTextReader xreader = new XmlTextReader(new StringReader(sxml.Replace("&", "&amp;"))))
        {
            XmlSerializer xs = new XmlSerializer(typeof(T));
            return (T)xs.Deserialize(xreader);
        }
    }

    public static string SerializeObjectToString(this object obj)
    {
        using (MemoryStream stream = new MemoryStream())
        {
            XmlSerializer x = new XmlSerializer(obj.GetType());
            x.Serialize(stream, obj);
            return Encoding.Default.GetString(stream.ToArray());
        }
    }
}

当然,数组中的第一个字符串将是键。

于 2013-03-06T18:44:17.810 回答
0

解决方案似乎比我想象的要简单,但实际上取决于选择正确的模型属性组合来正确解析。

这是我决定使用的一个,因为它将每个条目分成自己的列表项。

[XmlRoot("ConfigurationMap")]
public class ConfigurationMap
{
    [XmlArray("mapConfig")]
    [XmlArrayItem("entry")]
    public List<Entry> MapConfig { get; set; }

}

[XmlRoot("entry")]
public class Entry
{
    [XmlElement("string")]
    public List<string> entry { get; set; }
}

希望这对其他人有帮助。感谢大家的意见和建议。

于 2013-03-07T20:05:19.423 回答