.NET 5 이상에서는 일반 속성과 마찬가지로 JsonPropertyName
을 직접 사용하여 열거형 값에 대한 사용자 지정 값을 지정할 수 없습니다. 이 기능은 기본적으로 사용할 수 없습니다.
이 문제를 해결하기 위해 우리는 JsonEnumMemberStringEnumConverter
을 활용하고 JsonStringEnumConverter
주석이 달린 각 열거형 유형에 대해 사용자 정의 [EnumMember(Value="xxx")]
를 사용하도록 조정하는 JsonConverter 팩토리(JsonNamingPolicy
)를 도입했습니다. 예:
<code class="language-csharp">[EnumMember(Value = "Trick-Or-Treat")] // 自定义值 public enum Example { Trick, Treat, TrickOrTreat }</code>
맞춤형 변환기 등록 및 사용:
<code class="language-csharp">var options = new JsonSerializerOptions { Converters = { new JsonEnumMemberStringEnumConverter() }, // ... }; var json = JsonSerializer.Serialize(values, options);</code>
이 변환기에는 다음과 같은 장점이 있습니다.
JsonStringEnumConverter
과 일치하는 동일한 값을 가진 열거형을 처리합니다. 또는 설치 후 다음과 같이 열거형에 주석을 달 수 있는 Macross.Json.Extensions
을 제공하는 JsonStringEnumMemberConverter
패키지를 사용할 수 있습니다.
<code class="language-csharp">[JsonConverter(typeof(System.Text.Json.Serialization.JsonStringEnumMemberConverter))] public enum Example { Trick, Treat, [EnumMember(Value="Trick-Or-Treat")] TrickOrTreat }</code>
더 세밀한 제어가 필요하거나 6.0 이전 버전의 .NET에서 사용자 정의 값이 있는 열거형을 지원해야 하는 경우 처음부터 일반 변환기 팩토리 및 변환기를 만들 수 있습니다. 이 접근 방식은 더 복잡하며 이전 버전의 경우 백포트가 필요할 수 있습니다.
[Flags]
속성이 있는 열거 유형에는 수정된 JsonConverter
이 필요할 수 있습니다. 이 상황을 처리하는 방법에 대한 자세한 내용은 응답의 지침을 참조하세요. JsonStringEnumConverter
는 역직렬화 중에 해당 JsonNamingPolicy
을 무시했습니다. 이 문제는 풀 요청 73348에서 해결되었습니다. [EnumMember]
및 [JsonPropertyName]
속성이 모두 있는 경우 사용자 지정 변환기의 [EnumMember]
값이 우선 적용됩니다. 위 내용은 System.Text.Json에서 열거형 값을 사용자 정의하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!