
在為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中文網其他相關文章!