Open.Serialization.Json.System
2.3.1
Extentions and DI utilities for System.Text.Json.
Part of the "Open" set of libraries.
Install-Package Open.Serialization.Json.System -Version 2.3.1
dotnet add package Open.Serialization.Json.System --version 2.3.1
<PackageReference Include="Open.Serialization.Json.System" Version="2.3.1" />
paket add Open.Serialization.Json.System --version 2.3.1
Open.Serialization
DI/IoC agnostic interfaces for injecting any serialization library.
Implementation
With the following libraries, you can build other libraries that sever their dependency from any serializer and allow you to inject whichever you want. You can also easily integrate another serializer and still retain the DI/IoC happiness.
Core Interfaces & Extensions
https://www.nuget.org/packages/Open.Serialization
Core package for serializing anything.
https://www.nuget.org/packages/Open.Serialization.Json
Core package specific to JSON.
Library/Vendor Specific Implementations
services.AddJsonSerializer();
The following libs contain support for Microsoft.Extensions.DependencyInjection
.
Import any of these and you can use the above extension to inject default serializers.
https://www.nuget.org/packages/Open.Serialization.Json.Newtonsoft
Extensions and DI for Newtonsoft.Json.
https://www.nuget.org/packages/Open.Serialization.Json.System
Extensions and DI for System.Text.Json. Note: There is no
IJsonObjectSerializer
option for System.Text.Json
.
https://www.nuget.org/packages/Open.Serialization.Json.Utf8Json
Extensions and DI for Utf8Json.
Interface & Methods Exposed
T IDeserialize.Deserialize<T>(string value);
T IDeserialize<T>.Deserialize(string value);
object IDeserializeObject.Deserialize(string value, Type type);
ValueTask<T> IDeserializeAsync.DeserializeAsync<T>(Stream source, CancellationToken cancellationToken = default);
ValueTask<T> IDeserializeAsync<T>.DeserializeAsync(Stream source, CancellationToken cancellationToken = default);
ValueTask<object> IDeserializeObjectAsync.DeserializeAsync(Stream source, Type type, CancellationToken cancellationToken = default);
string ISerialize.Serialize<T>(T item);
string ISerialize<T>.Serialize(T item);
string ISerializeObject.Serialize(object item, Type type);
ValueTask ISerializeAsync.SerializeAsync<T>(Stream target, T item, CancellationToken cancellationToken = default);
ValueTask ISerializeAsync<T>.SerializeAsync(Stream target, T item, CancellationToken cancellationToken = default);
ValueTask ISerializeObjectAsync.SerializeAsync(Stream target, object item, Type type, CancellationToken cancellationToken = default);
Open.Serialization
DI/IoC agnostic interfaces for injecting any serialization library.
Implementation
With the following libraries, you can build other libraries that sever their dependency from any serializer and allow you to inject whichever you want. You can also easily integrate another serializer and still retain the DI/IoC happiness.
Core Interfaces & Extensions
https://www.nuget.org/packages/Open.Serialization
Core package for serializing anything.
https://www.nuget.org/packages/Open.Serialization.Json
Core package specific to JSON.
Library/Vendor Specific Implementations
services.AddJsonSerializer();
The following libs contain support for Microsoft.Extensions.DependencyInjection
.
Import any of these and you can use the above extension to inject default serializers.
https://www.nuget.org/packages/Open.Serialization.Json.Newtonsoft
Extensions and DI for Newtonsoft.Json.
https://www.nuget.org/packages/Open.Serialization.Json.System
Extensions and DI for System.Text.Json. Note: There is no
IJsonObjectSerializer
option for System.Text.Json
.
https://www.nuget.org/packages/Open.Serialization.Json.Utf8Json
Extensions and DI for Utf8Json.
Interface & Methods Exposed
T IDeserialize.Deserialize<T>(string value);
T IDeserialize<T>.Deserialize(string value);
object IDeserializeObject.Deserialize(string value, Type type);
ValueTask<T> IDeserializeAsync.DeserializeAsync<T>(Stream source, CancellationToken cancellationToken = default);
ValueTask<T> IDeserializeAsync<T>.DeserializeAsync(Stream source, CancellationToken cancellationToken = default);
ValueTask<object> IDeserializeObjectAsync.DeserializeAsync(Stream source, Type type, CancellationToken cancellationToken = default);
string ISerialize.Serialize<T>(T item);
string ISerialize<T>.Serialize(T item);
string ISerializeObject.Serialize(object item, Type type);
ValueTask ISerializeAsync.SerializeAsync<T>(Stream target, T item, CancellationToken cancellationToken = default);
ValueTask ISerializeAsync<T>.SerializeAsync(Stream target, T item, CancellationToken cancellationToken = default);
ValueTask ISerializeObjectAsync.SerializeAsync(Stream target, object item, Type type, CancellationToken cancellationToken = default);
Dependencies
-
.NETStandard 2.0
- Microsoft.Extensions.DependencyInjection (>= 3.1.6)
- Open.Serialization.Json (>= 2.3.1)
- System.Text.Json (>= 4.7.0)
-
.NETStandard 2.1
- Microsoft.Extensions.DependencyInjection (>= 3.1.6)
- Open.Serialization.Json (>= 2.3.1)
- System.Text.Json (>= 4.7.0)
Used By
NuGet packages (7)
Showing the top 5 NuGet packages that depend on Open.Serialization.Json.System:
Package | Downloads |
---|---|
Convey.WebApi
Convey.WebApi
|
|
MicroBootstrap
MicroBootstrap is a framework for quickly and conveniently creating microservices on .NET Core.
|
|
Joint.WebApi
This package its created for common functionality.
|
|
Else.Convey.WebApi
Convey.WebApi
|
|
Joint.Exception
This package its created for common functionality.
|
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on Open.Serialization.Json.System:
Repository | Stars |
---|---|
snatch-dev/Convey
A simple recipe for .NET Core microservices.
|