Typer som stöds i System.Text.Json
Den här artikeln ger en översikt över vilka typer som stöds för serialisering och deserialisering.
Typer som serialiseras som JSON-objekt
Följande typer serialiserar som JSON-objekt:
- Klasser*
- Structs
- Gränssnitt
- Poster och struct-poster
* Icke-ordlistetyper som implementerar IEnumerable<T> serialisera som JSON-matriser. Ordlistetyper, som implementerar IEnumerable<T>, serialiserar som JSON-objekt.
Följande kodfragment visar serialiseringen av en enkel struct.
public static void Main()
{
var coordinates = new Coords(1.0, 2.0);
string json = JsonSerializer.Serialize(coordinates);
Console.WriteLine(json);
// Output:
// {"X":1,"Y":2}
}
public readonly struct Coords
{
public Coords(double x, double y)
{
X = x;
Y = y;
}
public double X { get; }
public double Y { get; }
}
Typer som serialiseras som JSON-matriser
.NET-samlingstyper serialiseras som JSON-matriser. System.Text.Json.JsonSerializer stöder en samlingstyp för serialisering om den:
- Härleds från IEnumerable eller IAsyncEnumerable<T>.
- Innehåller element som kan serialiseras.
Serialiseraren anropar metoden GetEnumerator() och skriver elementen.
Deserialisering är mer komplicerat och stöds inte för vissa samlingstyper.
Följande avsnitt ordnas efter namnområde och visar vilka typer som stöds för serialisering och deserialisering.
- System.Array-namnområde
- System.Collections namnområde
- System.Collections.Generic
- System.Collections.Oföränderlig namnrymd
- System.Collections.Specialized
- System.Collections.Concurrent
- System.Collections.ObjectModel-namnområde
- Anpassade samlingar
System.Array-namnområde
Typ | Serialisering | Deserialisering |
---|---|---|
endimensionella matriser | ✔️ | ✔️ |
flerdimensionella matriser | ❌ | ❌ |
Jagged-matriser | ✔️ | ✔️ |
System.Collections-namnområde
Typ | Serialisering | Deserialisering |
---|---|---|
ArrayList | ✔️ | ✔️ |
BitArray | ✔️ | ❌ |
DictionaryEntry | ✔️ | ✔️ |
Hashtable | ✔️ | ✔️ |
ICollection | ✔️ | ✔️ |
IDictionary | ✔️ | ✔️ |
IEnumerable | ✔️ | ✔️ |
IList | ✔️ | ✔️ |
Queue | ✔️ | ✔️ |
SortedList | ✔️ | ✔️ |
Stack * | ✔️ | ✔️ |
* Se Support tur och retur för Stack
typer.
System.Collections.Generic-namnområde
Typ | Serialisering | Deserialisering |
---|---|---|
Dictionary<TKey,TValue> * | ✔️ | ✔️ |
HashSet<T> | ✔️ | ✔️ |
IAsyncEnumerable<T> † | ✔️ | ✔️ |
ICollection<T> | ✔️ | ✔️ |
IDictionary<TKey,TValue> * | ✔️ | ✔️ |
IEnumerable<T> | ✔️ | ✔️ |
IList<T> | ✔️ | ✔️ |
IReadOnlyCollection<T> | ✔️ | ✔️ |
IReadOnlyDictionary<TKey,TValue> * | ✔️ | ✔️ |
IReadOnlyList<T> | ✔️ | ✔️ |
ISet<T> | ✔️ | ✔️ |
KeyValuePair<TKey,TValue> | ✔️ | ✔️ |
LinkedList<T> | ✔️ | ✔️ |
LinkedListNode<T> | ✔️ | ❌ |
List<T> | ✔️ | ✔️ |
Queue<T> | ✔️ | ✔️ |
SortedDictionary<TKey,TValue> * | ✔️ | ✔️ |
SortedList<TKey,TValue> * | ✔️ | ✔️ |
SortedSet<T> | ✔️ | ✔️ |
Stack<T> ‡ | ✔️ | ✔️ |
* Se nyckeltyper som stöds.
† Se följande avsnitt om IAsyncEnumerable<T>
.
‡ Se Support tur och retur för Stack
typer.
IAsyncEnumerable<T>
I följande exempel används strömmar som en representation av alla asynkrona datakällor. Källan kan vara filer på en lokal dator eller resultat från en databasfråga eller ett API-anrop för webbtjänsten.
Stream-serialisering
System.Text.Json
stöder serialisering av IAsyncEnumerable<T> värden som JSON-matriser, enligt följande exempel:
using System.Text.Json;
namespace IAsyncEnumerableSerialize;
public class Program
{
public static async Task Main()
{
using Stream stream = Console.OpenStandardOutput();
var data = new { Data = PrintNumbers(3) };
await JsonSerializer.SerializeAsync(stream, data);
}
static async IAsyncEnumerable<int> PrintNumbers(int n)
{
for (int i = 0; i < n; i++)
{
await Task.Delay(1000);
yield return i;
}
}
}
// output:
// {"Data":[0,1,2]}
IAsyncEnumerable<T>
värden stöds endast av asynkrona serialiseringsmetoder, till exempel JsonSerializer.SerializeAsync.
Stream-deserialisering
Metoden DeserializeAsyncEnumerable
stöder strömmande deserialisering, som du ser i följande exempel:
using System.Text;
using System.Text.Json;
namespace IAsyncEnumerableDeserialize;
public class Program
{
public static async Task Main()
{
using var stream = new MemoryStream(Encoding.UTF8.GetBytes("[0,1,2,3,4]"));
await foreach (int item in JsonSerializer.DeserializeAsyncEnumerable<int>(stream))
{
Console.WriteLine(item);
}
}
}
// output:
//0
//1
//2
//3
//4
Metoden DeserializeAsyncEnumerable
stöder endast läsning från JSON-matriser på rotnivå.
Metoden DeserializeAsync stöder IAsyncEnumerable<T>
, men signaturen tillåter inte strömning. Det returnerar slutresultatet som ett enda värde, som du ser i följande exempel.
using System.Text;
using System.Text.Json;
namespace IAsyncEnumerableDeserializeNonStreaming;
public class MyPoco
{
public IAsyncEnumerable<int>? Data { get; set; }
}
public class Program
{
public static async Task Main()
{
using var stream = new MemoryStream(Encoding.UTF8.GetBytes(@"{""Data"":[0,1,2,3,4]}"));
MyPoco? result = await JsonSerializer.DeserializeAsync<MyPoco>(stream)!;
await foreach (int item in result!.Data!)
{
Console.WriteLine(item);
}
}
}
// output:
//0
//1
//2
//3
//4
I det här exemplet buffrar deserialiseraren allt IAsyncEnumerable<T>
innehåll i minnet innan det deserialiserade objektet returneras. Det här beteendet är nödvändigt eftersom deserialiseraren måste läsa hela JSON-nyttolasten innan resultatet returneras.
System.Collections.Oföränderligt namnområde
Typ | Serialisering | Deserialisering |
---|---|---|
IImmutableDictionary<TKey,TValue> † | ✔️ | ✔️ |
IImmutableList<T> | ✔️ | ✔️ |
IImmutableQueue<T> | ✔️ | ✔️ |
IImmutableSet<T> | ✔️ | ✔️ |
IImmutableStack<T> * | ✔️ | ✔️ |
ImmutableArray<T> | ✔️ | ✔️ |
ImmutableDictionary<TKey,TValue> † | ✔️ | ✔️ |
ImmutableHashSet<T> | ✔️ | ✔️ |
ImmutableQueue<T> | ✔️ | ✔️ |
ImmutableSortedDictionary<TKey,TValue> † | ✔️ | ✔️ |
ImmutableSortedSet<T> | ✔️ | ✔️ |
ImmutableStack<T> * | ✔️ | ✔️ |
* Se Support tur och retur för Stack
typer.
† Se nyckeltyper som stöds.
System.Collections.Specialized namespace
Typ | Serialisering | Deserialisering |
---|---|---|
BitVector32 | ✔️ | ❌* |
HybridDictionary | ✔️ | ✔️ |
IOrderedDictionary | ✔️ | ❌ |
ListDictionary | ✔️ | ✔️ |
NameValueCollection | ✔️ | ❌ |
StringCollection | ✔️ | ❌ |
StringDictionary | ✔️ | ❌ |
* När BitVector32 deserialiseras hoppas egenskapen Data över eftersom den inte har någon offentlig setter. Inget undantag utlöses.
System.Collections.Concurrent-namnområde
Typ | Serialisering | Deserialisering |
---|---|---|
BlockingCollection<T> | ✔️ | ❌ |
ConcurrentBag<T> | ✔️ | ❌ |
ConcurrentDictionary<TKey,TValue> † | ✔️ | ✔️ |
ConcurrentQueue<T> | ✔️ | ✔️ |
ConcurrentStack<T> * | ✔️ | ✔️ |
* Se Support tur och retur för Stack
typer.
† Se nyckeltyper som stöds.
System.Collections.ObjectModel-namnrymd
Typ | Serialisering | Deserialisering |
---|---|---|
Collection<T> | ✔️ | ✔️ |
KeyedCollection<sträng, TValue> * | ✔️ | ❌ |
ObservableCollection<T> | ✔️ | ✔️ |
ReadOnlyCollection<T> | ✔️ | ❌ |
ReadOnlyDictionary<TKey,TValue> | ✔️ | ❌ |
ReadOnlyObservableCollection<T> | ✔️ | ❌ |
* Icke-string
nycklar stöds inte.
Anpassade samlingar
Alla samlingstyper som inte finns i någon av de föregående namnrymderna anses vara en anpassad samling. Sådana typer omfattar användardefinierade typer och typer som definieras av ASP.NET Core. Till exempel finns Microsoft.Extensions.Primitives i den här gruppen.
Alla anpassade samlingar (allt som härleds från IEnumerable
) stöds för serialisering, så länge deras elementtyper stöds.
Stöd för deserialisering
En anpassad samling stöds för deserialisering om den:
Är inte ett gränssnitt eller abstrakt.
Har en parameterlös konstruktor.
Innehåller elementtyper som stöds av JsonSerializer.
Implementerar eller ärver ett eller flera av följande gränssnitt eller klasser:
- ConcurrentQueue<T>
- ConcurrentStack<T> *
- ICollection<T>
- IDictionary
- IDictionary<TKey,TValue> †
- IList
- IList<T>
- Queue
- Queue<T>
- Stack *
- Stack<T> *
* Se Support tur och retur för
Stack
typer.† Se nyckeltyper som stöds.
Kända problem
Det finns kända problem med följande anpassade samlingar:
- ExpandoObject: Se dotnet/runtime#29690.
- DynamicObject: Se dotnet/runtime#1808.
- DataTable: Se dotnet/docs#21366.
- Microsoft.AspNetCore.Http.FormFile: Se dotnet/runtime#1559.
- Microsoft.AspNetCore.Http.IFormCollection: Se dotnet/runtime#1559.
Mer information om kända problem finns i öppna problem i System.Text.Json.
Nyckeltyper som stöds
När de används som nycklar för Dictionary
och SortedList
typer har följande typer inbyggt stöd:
Boolean
Byte
DateTime
DateTimeOffset
Decimal
Double
Enum
Guid
Int16
Int32
Int64
-
Object
(Endast vid serialisering och om körningstypen är en av de typer som stöds i den här listan.) SByte
Single
String
- TimeSpan
UInt16
UInt32
UInt64
- Uri
- Version
Med metoderna JsonConverter<T>.WriteAsPropertyName(Utf8JsonWriter, T, JsonSerializerOptions) och JsonConverter<T>.ReadAsPropertyName(Utf8JsonReader, Type, JsonSerializerOptions) kan du dessutom lägga till stöd för ordlistenycklar för valfri typ.
Typer som inte stöds
Följande typer stöds inte för serialisering:
- System.Type och System.Reflection.MemberInfo
- ReadOnlySpan<T>, Span<T>och ref structs i allmänhet
- Delegera typer
- IntPtr och UIntPtr
System.Data-namnrymd
Det finns inga inbyggda konverterare för DataSet, DataTableoch relaterade typer i System.Data namnområdet. Det är inte säkert att deserialisera dessa typer från ej betrodda indata, vilket beskrivs i säkerhetsvägledningen. Du kan dock skriva en anpassad konverterare för att stödja dessa typer. Exempel på anpassad konverterarkod som serialiserar och deserialiserar en DataTable
finns i RoundtripDataTable.cs.