ASP.NET 애플리케이션에서는 복잡한 JSON 응답 데이터를 DTO(Data Transfer Object)로 추출해야 하는 경우가 많습니다. RestSharp와 같은 도구를 사용하면 API에서 JSON 데이터를 얻는 것이 상대적으로 쉽지만 복잡한 응답에서 DTO를 만드는 것은 여전히 어려운 일입니다.
다음 JSON 응답을 가정합니다.
<code class="language-json">{ "response": { "result": { "Leads": { "row": [ { "no": "1", "FL": [ { "val": "LEADID", "content": "101" }, { "val": "Company", "content": "Test 1" } ] }, { "no": "2", "FL": [ { "val": "LEADID", "content": "102" }, { "val": "Company", "content": "Test 2" } ] } ] } }, "uri": "/crm/private/json/Leads/getRecords" } }</code>
목표는 이 JSON 응답에서 리드 목록을 DTO로 추출하는 것입니다. 각 DTO에는 "LEADID" 및 "회사" 속성이 포함되어 있습니다.
Visual Studio에서는 JSON 구조를 기반으로 C# 클래스를 자동으로 생성할 수 있는 "JSON을 클래스로 붙여넣기"라는 편리한 기능을 제공합니다.
단계:
제공된 JSON 응답에 대해 다음 클래스가 생성됩니다.
<code class="language-csharp">public class Rootobject { public Response response { get; set; } } public class Response { public Result result { get; set; } public string uri { get; set; } } public class Result { public Leads Leads { get; set; } } public class Leads { public Row[] row { get; set; } } public class Row { public string no { get; set; } public FL[] FL { get; set; } } public class FL { public string val { get; set; } public string content { get; set; } }</code>
이제 C# 클래스가 있으므로 LeadDto 클래스를 정의할 수 있습니다.
<code class="language-csharp">public class LeadDto { public string LeadId { get; set; } public string Company { get; set; } }</code>
JSON 응답을 기반으로 LeadDto 목록을 채우려면 LINQ를 사용할 수 있습니다.
<code class="language-csharp">var leads = from response in Rootobject.response.result.Leads.row select new LeadDto { LeadId = response.FL.First(fl => fl.val == "LEADID").content, Company = response.FL.First(fl => fl.val == "Company").content };</code>
이 쿼리는 JSON 응답에서 추출된 "LEADID" 및 "회사" 속성을 각각 포함하는 LeadDto 개체 목록을 생성합니다.
위 내용은 ASP.NET의 복잡한 JSON 응답에서 C# DTO를 효율적으로 만드는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!