将JSON解析为对象

时间:2014-11-24 10:21:27

标签: c# json parsing json.net

我正在使用box api,并试图将json对象解析为一个类 这是json:

{
  "type":"folder",
  "id":"0",
  "sequence_id":null,
  "etag":null,
  "name":"All Files",
  "created_at":null,
  "modified_at":null,
  "description":"",
  "size":9049537,
  "path_collection":
  {
    "total_count":0,"entries":[]
  },
  "created_by":
  {
    "type":"user","id":"","name":"","login":""
  },
  "modified_by":
  {
    "type":"user",
    "id":"111",
    "name":"a a",
    "login":"a@gmail.com"
  },
  "trashed_at":null,
  "purged_at":null,
  "content_created_at":null,
  "content_modified_at":null,
  "owned_by":
  {
    "type":"user",
    "id":"111",
    "name":"a a",   
    "login":"a@gmail.com"   
  },    
  "shared_link":null,
  "folder_upload_email":null,
  "parent":null,
  "item_status":"active",
  "item_collection":
  {
    "total_count":4,
    "entries":
    [
      {
        "type":"file",
        "id":"22887167395",
        "sequence_id":"0",
        "etag":"0",
        "sha1":"883c99863eefc0f46b3d34915cc4d97a6008fabf",
        "name":"13.ppt"
      },
      {
        "type":"file",
        "id":"22887169687",
        "sequence_id":"0",
        "etag":"0",
        "sha1":"a345fd68b1c90a3678a3e746e0e5343693d8a022",
        "name":"6.docx"
      }
    ],
    "offset":0,
    "limit":100,
    "order":
    [
      {
        "by":"type",
        "direction":"ASC"
      },
      {
        "by":"name",
        "direction":"ASC"
      }
    ]
  }
}

基本上,这是包含两个文件的根文件夹(在这种情况下):
13.ppt
6.docx
我创建了一个类:

[JsonObject(MemberSerialization.OptIn)]
public class BoxFile
{
    [JsonProperty(PropertyName = "type")]
    public string Type { get; internal set; }

    [JsonProperty(PropertyName = "id")]
    public string Id { get; internal set; }

    [JsonProperty(PropertyName = "sequence_id")]
    public string SequenceId { get; internal set; }

    [JsonProperty(PropertyName = "etag")]
    public string Etag { get; internal set; }

    [JsonProperty(PropertyName = "name")]
    public string Name { get; internal set; }

    [JsonProperty(PropertyName = "created_at")]
    public string CreatedAt { get; internal set; }

    [JsonProperty(PropertyName = "modified_at")]
    public string ModifiedAt { get; internal set; }

    [JsonProperty(PropertyName = "description")]
    public string Description { get; internal set; }

    [JsonProperty(PropertyName = "size")]
    public long Size { get; internal set; }

    [JsonProperty(PropertyName = "item_collection")]
    public IEnumerable<BoxFile> ItemCollection { get; internal set; }
}  

但是“item_collection”部分无效..它给了我一个错误..

如何在“item_collection”中获取子文件列表?

我用它:

    private T ParseJson<T>(string json) where T : class, new()
    {
            JObject jobject = JObject.Parse(json);
            return JsonConvert.DeserializeObject<T>(jobject.ToString());
    }  

并且:

BoxFile parsed = ParseJson<BoxFile>(json);

1 个答案:

答案 0 :(得分:1)

您收到错误,因为您的类结构与您的JSON不匹配。具体来说,在JSON中,item_collection属性是一个对象,而不是一个列表。该JSON对象有两个属性total_countentries,后者包含实际的文件列表。要处理此问题,您需要定义另一个类:

public class ItemCollection
{
    [JsonProperty(PropertyName = "entries")]
    public IEnumerable<BoxFile> Entries { get; internal set; }
}

然后更改ItemCollection类中的BoxFile属性以使用此新类:

    [JsonProperty(PropertyName = "item_collection")]
    public ItemCollection ItemCollection { get; internal set; }

然后,您可以访问以下文件列表:

BoxFile parsed = ParseJson<BoxFile>(json);

foreach (BoxFile file in parsed.ItemCollection.Entries)
{
    Console.WriteLine(file.Name);
}

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

另外,您可以将ParseJson方法简化为一行。无需将JSON解析为JObject,将其重新转换为JSON,然后再次解析。

private T ParseJson<T>(string json) where T : class, new()
{
    return JsonConvert.DeserializeObject<T>(json);
}