使用动态密钥将JSON反序列化为Object

时间:2019-02-09 21:59:48

标签: json dynamic model json.net key

我知道已经对该主题提出了一些问题,但是我仍然很难理解。我有一个返回的相当复杂的JSON对象,它在开始时有一个动态密钥。我正在尝试将其反序列化为C#对象模型,但是我的问题是动态键:

{
"ISBN:0903393972": {
    "bib_key": "ISBN:0903393972",
    "details": {
        "publishers": ["Sweet & Maxwell"],
        "physical_format": "Hardcover",
        "title": "Tanker Voyage Charter Parties",
        "created": {
            "type": "/type/datetime",
            "value": "2008-04-30T09:38:13.731961"
        },
        "authors": [{
            "name": "F.M. Ventris",
            "key": "/authors/OL3610236A"
        }],
}}}

我的头痛来自动态的“ ISBN:0903393972”部分。以下也是该模型的一部分:

[DataContract]
public class Created
{
    [DataMember]
    public string type { get; set; }
    [DataMember]
    public DateTime value { get; set; }
}

[DataContract]
public class Author
{
    [DataMember]
    public string name { get; set; }
    [DataMember]
    public string key { get; set; }
}

[DataContract]
public class Details
{
    [DataMember]
    public List<string> publishers { get; set; }
    [DataMember]
    public string physical_format { get; set; }
    [DataMember]
    public string title { get; set; }
    [DataMember]
    public Created created { get; set; }
    [DataMember]
    public List<Author> authors { get; set; }
}

[DataContract]
public class ISBN
{
    [DataMember]
    public string bib_key { get; set; }
    [DataMember]
    public Details details { get; set; }
}

[DataContract]
public class RootObject
{
    public Dictionary<string, ISBN> bookRoot { get; set; }
}

我正在使用以下代码反序列化JSON格式(在我将“ ISBN:0903393972”硬编码为对象密钥的情况下有效):

        string json = new WebClient().DownloadString(URLAddress);
        JObject book = JObject.Parse(json) as JObject;

        // Copy to a static Album instance
        RootObject deserializedBook = book.ToObject<RootObject>();

        return deserializedBook;

我确定我在这里遗漏了一些东西,但是他整天都在努力寻找解决方案。任何帮助将不胜感激!

1 个答案:

答案 0 :(得分:0)

您很近。

在JSON中,动态键位于根级别,因此该对象需要用locateClickCheckbox("Add/Update Network Security") locateClickCheckbox("Create User") locateClickCheckbox("Create Project") locateClickCheckbox("Update User Details") locateClickCheckbox("View User") locateClickCheckbox("Assign Permissions") 表示。看来您已经意识到这一点,但是,在您的模型中,您添加了一个外部类来包含字典。这与JSON不一致,这里不需要。相反,您应该直接反序列化到字典中:

Dictionary<string, ISBN>

您可以从那里遍历字典上的string json = new WebClient().DownloadString(URLAddress); var bookRoot = JsonConvert.DeserializeObject<Dictionary<string, ISBN>>(json); 集合来访问书籍,而无需事先知道键:

Values

或者,如果您只希望读一本书,可以从字典中获取,如下所示:

foreach (var isbn in bookRoot.Values)
{
    // ...
}

这是一个有效的演示:https://dotnetfiddle.net/csgSKp