2017-01-23 3 views
0

У меня есть следующий JSON вернулся из DocumentumКак десериализации JSON из Documentum REST службы

{ 
    "resources" : { 
     "http://identifiers.emc.com/linkrel/repositories" : { 
      "href" : "http://stg1docapp10:7000/dctm-rest/repositories.json", 
      "hints" : { 
       "allow" : ["GET"], 
       "representations" : ["application/xml", "application/json", "application/atom+xml", "application/vnd.emc.documentum+json"] 
      } 
     }, 
     "about" : { 
      "href" : "http://stg1docapp10:7000/dctm-rest/product-info.json", 
      "hints" : { 
       "allow" : ["GET"], 
       "representations" : ["application/xml", "application/json", "application/vnd.emc.documentum+xml", "application/vnd.emc.documentum+json"] 
      } 
     } 
    } 
} 

То, что я пытаюсь найти, как преобразовать это в класс;

Я попытался

Dictionary<String,String> ds = JsonConvert.DeserializeObject<Dictionary<String, String>>(result); 

и я попытался определения следующий класс и десериализации его в этом.

public class DocumentumServices 
    : IDisposable 
{ 
    public String href { get; set; } 
    public IList<String> hints { get; set; } 

    public void Dispose() 
    { 

    } 
} 
+1

Почему бы не попробовать с помощью онлайн-генератора POCO, например, http://json2csharp.com? – Miki

ответ

1

К сожалению, DeserializeObject cannnot делать то, что вы хотите, просто. Если вы хотите простое решение, вы можете попробовать использовать LINQ для JSON:

var ds = JObject.Parse(result); 
var list = (from doc in ds["resources"] 
      select doc.Values().ToDictionary(k => ((JProperty)k).Name, 
              v => v.Children().First()) into gr 
      select new DocumentumServices() { 
       href = gr["href"].ToString(), 
       hints = (from hnt in gr["hints"] select hint.ToString()).ToList() 
      }).ToList(); 

Вы можете даже разлагаться hints дальше так:

public class DocumentumServices 
{ 
    public string href { get; set; } 
    public Dictionary<string, List<string>> hints { get; set; } 
} 
// ... 

var ds = JObject.Parse(result); 
var list = (from doc in ds["resources"] 
      select doc.Values().ToDictionary(k => ((JProperty)k).Name, v => v.Children().First()) into gr 
      select new DocumentumServices() { 
       href = gr["href"].ToString(), 
       hints = (from hint in gr["hints"] 
         select new { 
          Key = hint.Path.Substring(hint.Path.LastIndexOf('.')+1), 
          Value = hint.Children().First().Select(x => x.ToString()).ToList() 
         }).ToDictionary(k => k.Key, v => v.Value) 
      }).ToList(); 

Если вы намеревались использовать это часто в вашем кода, вы должны сделать его в обычном JsonConverter для использования с DeserializeObject.

Смежные вопросы