Microsoft MVP성태의 닷넷 이야기
.NET Framework: 2115. System.Text.Json의 역직렬화 시 필드/속성 주의 [링크 복사], [링크+제목 복사],
조회: 14933
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)
(시리즈 글이 9개 있습니다.)
.NET Framework: 351. JavaScriptSerializer, DataContractJsonSerializer, Json.NET
; https://www.sysnet.pe.kr/2/0/1391

.NET Framework: 661. Json.NET의 DeserializeObject 수행 시 속성 이름을 동적으로 바꾸는 방법
; https://www.sysnet.pe.kr/2/0/11224

.NET Framework: 756. JSON의 escape sequence 문자 처리 방식
; https://www.sysnet.pe.kr/2/0/11532

사물인터넷: 54. 아두이노 환경에서의 JSON 파서(ArduinoJson) 사용법
; https://www.sysnet.pe.kr/2/0/11766

.NET Framework: 1073. C# - JSON 역/직렬화 시 리플렉션 손실을 없애는 JsonSrcGen
; https://www.sysnet.pe.kr/2/0/12688

.NET Framework: 2087. .NET 6부터 SourceGenerator와 통합된 System.Text.Json
; https://www.sysnet.pe.kr/2/0/13214

.NET Framework: 2115. System.Text.Json의 역직렬화 시 필드/속성 주의
; https://www.sysnet.pe.kr/2/0/13342

닷넷: 2261. C# - 구글 OAuth의 JWT (JSON Web Tokens) 해석
; https://www.sysnet.pe.kr/2/0/13623

닷넷: 2265. C# - System.Text.Json의 기본적인 (한글 등에서의) escape 처리
; https://www.sysnet.pe.kr/2/0/13644




System.Text.Json의 역직렬화 시 필드/속성 주의

다음은 간단한 System.Text.Json 예제입니다.

using System.Text.Json;

internal class Program
{
    private static void Main(string[] args)
    {
        string text = """
            {
                "id": "test",
                "data": [
                    {
                        "id": "test"
                    }
                ]
            }
            """;

        DataList? models = JsonSerializer.Deserialize<DataList>(text);
        Console.WriteLine(models?.data.Count);
    }
}

public class DataList
{
    public string id { get; set; } = "";
    public List<Data> data { get; set; } = new List<Data>();
}

public class Data
{
    public string id { get; set; } = "";
}

그런데, 무심코 이렇게 정의하면 안 됩니다. ^^;

public class DataList
{
    public string id { get; set; } = "";
    public List<Data> data;
}

그나마 위와 같이 하면 data.Count 접근 시 data가 null이어서 예외가 발생하는데요, 이것을 다음과 같이 바꾸면,

public class DataList
{
    public string id { get; set; } = "";
    public List<Data> data = new List<Data>();
}

data.Count에서 0이 나와 결과가 왜 저렇게 나오는지, 게다가 저게 하필 배열이라 뭔가 다른 방법이 있어야만 하는 것인지 자칫 (저처럼) 헤맬 수가 있습니다. 사실 저게 몇 개 안 되는 필드/멤버를 가진 경우에는 금방 표가 나서 쉽게 구분이 되지만 필드가 많아지면 쉽게 식별하지 못할 수 있습니다.

따라서, 처음 예제처럼 get/set 접근자를 사용하든가, 아니면 JsonInclude 특성을 포함하면 문제가 해결됩니다.

public class DataList
{
    public string id { get; set; } = "";

    [JsonInclude]
    public List<Data> data = new List<Data>();
}




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 5/8/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13989정성태8/8/20253370닷넷: 2352. C# - Windows S-mode 환경인지 체크하는 방법파일 다운로드1
13988정성태8/8/20253302오류 유형: 974. 비주얼 스튜디오 업데이트 시 잠김 파일 경고 - Visual Studio Standard Collector Service 150 (VSStandardCollectorService150)
13987정성태8/7/20252836닷넷: 2351. C# 14 - (6) event와 생성자에도 partial 메서드 적용파일 다운로드1
13986정성태8/6/20252391닷넷: 2350. C# 14 - (5) 람다 매개 변수에 접근자가 있는 경우에도 타입 생략 가능파일 다운로드1
13985정성태8/6/20253097오류 유형: 973. "wsl --install" 명령어 수행 시 "The server name or address could not be resolved"
13984정성태8/6/20252817Windows: 282. 윈도우 운영체제에 추가된 ssh 서버(Win32-OpenSSH)
13983정성태8/4/20252701오류 유형: 972. Microsoft.Data.SqlClient 6.1.0 버전부터 .NET 8 이상만 지원
13982정성태8/2/20253026개발 환경 구성: 753. CentOS 7 컨테이너 내에서 openssh 서버 호스팅
13981정성태8/1/20252601오류 유형: 971. CentOS 7에서 yum 사용 시 "Could not resolve host: mirrorlist.centos.org; Unknown error"
13980정성태7/31/20252740Linux: 119. eBPF - BPF_PROG_TYPE_CGROUP_SOCK 유형에서 정상 동작하지 않는 BPF_CORE_READ (2)
13979정성태7/30/20253248Linux: 118. eBPF - BPF_PROG_TYPE_CGROUP_SOCK 유형에서 정상 동작하지 않는 BPF_CORE_READ
13978정성태7/29/20252658오류 유형: 970. 파일 복사 시 "Data error (cyclic redundancy check). (0x80070017)" 에러
13977정성태7/28/20253136닷넷: 2349. C# 14 - (4) 문자열 리터럴을 utf-8 인코딩으로 저장파일 다운로드1
13976정성태7/25/20252955닷넷: 2348. C# - 카카오 카나나 모델 + Microsoft.ML.OnnxRuntimeGenAI 예제파일 다운로드1
13975정성태7/23/20252837닷넷: 2347. C# 14 - (3) 형식 인자가 없는 제네릭 타입의 nameof 지원파일 다운로드1
13974정성태7/22/20253041닷넷: 2346. C# 14 - (2) Span 타입과 배열 간의 암시적 형변환파일 다운로드1
13973정성태7/21/20253186닷넷: 2345. C# - 배열 및 Span의 공변성파일 다운로드1
13972정성태7/21/20252839닷넷: 2344. C#의 Identity conversion 의미파일 다운로드1
13971정성태7/17/20253074닷넷: 2343. C# 14 - (1) 속성 구문에서 문맥 키워드로 추가되는 field 예약어파일 다운로드1
13970정성태7/17/20252766닷넷: 2342. C# 14 - (취소된 글)
13969정성태7/17/20252733닷넷: 2341. snap으로 설치한 .NET 리눅스 실행 환경
13968정성태7/16/20252743오류 유형: 969. lddtree - TypeError: 'type' object is not subscriptable
13967정성태7/16/20253524오류 유형: 968. snap으로 설치한 "dotnet run" 실행 시 "undefined symbol: _dl_audit_symbind_alt, version GLIBC_PRIVATE" 오류
13966정성태7/15/20254132디버깅 기술: 223. WinDbg - .kframes 명령어
13965정성태7/11/20253266오류 유형: 967. 디버깅 모드로 실행 시 "Could not find file 'C:\Program Files\IIS Express\Oracle.DataAccess.Common.Configuration.Section.xsd'" 예외
13964정성태7/10/20254668닷넷: 2340. C# - Win32 Multimedia Timer 주기파일 다운로드1
1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...