在為System.Text.Json開發自訂JSON轉換器時,您可能會遇到Write
方法中預設序列化就足夠的情況。為了實現這一點,可以考慮幾種方法。
如果將[JsonConverter]
屬性套用至特定屬性,則呼叫JsonSerializer.Serialize(writer, person, options);
將為此屬性產生預設序列化。
在自訂轉換器的Write
方法中,您可以建立傳入JsonSerializerOptions
的副本,從副本的Converters
清單中移除自訂轉換器,並將修改後的選項傳遞到JsonSerializer.Serialize<T>(Utf8JsonWriter, T, JsonSerializerOptions);
中。請注意,在處理遞歸類型時,此方法有其限制。
透過將JsonConverterFactory
定義為自訂轉換器的基類,您可以控制轉換器的建立。在工廠的CreateConverter
方法中,您可以建立一個巢狀的DefaultConverter
,該轉換器使用修改後的選項進行序列化和反序列化。
注意:此方法可能會導致堆疊溢位。
如果將JsonConverterFactory
應用於自訂值類型或POCO,則在序列化期間可能會發生堆疊溢位。
以下修改後的PersonConverter
示範如何使用自訂轉換器工廠實現預設序列化:
<code class="language-csharp">public sealed class PersonConverter : DefaultConverterFactory<Person> { ... // 使用修改后的选项实现Read和Write方法 public override bool CanConvert(Type typeToConvert) => typeof(Person) == typeToConvert; public override JsonConverter CreateConverter(Type typeToConvert, JsonSerializerOptions options) => new DefaultConverter(options, this); }</code>
在DefaultConverterFactory
基底類別中,CopyAndRemoveConverter
擴充方法用於建立選項的修改後的副本,並排除自訂轉換器。
與使用不同的JsonSerializerOptions
進行序列化和反序列化相比,此方法提供了更大的靈活性。
以上是如何在自訂 JSON 轉換器中利用預設 System.Text.Json 序列化?的詳細內容。更多資訊請關注PHP中文網其他相關文章!