Amazon.Lambda.Serialization.SystemTextJson
2.4.4
Prefix Reserved
dotnet add package Amazon.Lambda.Serialization.SystemTextJson --version 2.4.4
NuGet\Install-Package Amazon.Lambda.Serialization.SystemTextJson -Version 2.4.4
<PackageReference Include="Amazon.Lambda.Serialization.SystemTextJson" Version="2.4.4" />
paket add Amazon.Lambda.Serialization.SystemTextJson --version 2.4.4
#r "nuget: Amazon.Lambda.Serialization.SystemTextJson, 2.4.4"
// Install Amazon.Lambda.Serialization.SystemTextJson as a Cake Addin #addin nuget:?package=Amazon.Lambda.Serialization.SystemTextJson&version=2.4.4 // Install Amazon.Lambda.Serialization.SystemTextJson as a Cake Tool #tool nuget:?package=Amazon.Lambda.Serialization.SystemTextJson&version=2.4.4
Amazon.Lambda.Serialization.SystemTextJson
This package contains a custom Amazon.Lambda.Core.ILambdaSerializer
implementation which uses System.Text.Json to
serialize/deserialize .NET types in Lambda functions. This serializer targets .NET Core 3.1 so can not be used with
the .NET Core 2.1 Lambda runtime.
If targeting .NET Core 3.1 this serializer is highly recommend over Amazon.Lambda.Serialization.Json and can significantly reduce cold start performance in Lambda.
This serializer can be present on the assembly or on the handler method. If you specify both, the method attribute takes priority.
Here is an example of setting this attribute on the assembly.
[assembly: Amazon.Lambda.Core.LambdaSerializer(typeof(Amazon.Lambda.Serialization.SystemTextJson.DefaultLambdaJsonSerializer))]
And this is how the method can be applied to the handler method.
[Amazon.Lambda.Core.LambdaSerializer(typeof(Amazon.Lambda.Serialization.SystemTextJson.DefaultLambdaJsonSerializer))]
public Response CustomSerializerMethod(Request input)
{
...
}
Using C# source generator for serialization
C# 9 provides source generators, which allow code generation during compilation. This can reduce the use of reflection APIs and improve application startup time. .NET 6 updated the native JSON library System.Text.Json to use source generators, allowing JSON parsing without requiring reflection APIs.
To use the source generator for JSON serializing in Lambda, you must define a new empty class
in your project that derives from System.Text.Json.Serialization.JsonSerializerContext
. This
class must be a partial class because the source generator adds code to this class to handle
serialization. On the empty partial class, add the JsonSerializable
attribute for each .NET
type the source generator must generate the serialization code for.
Here is an example called HttpApiJsonSerializerContext that registers the Amazon API Gateway HTTP API event and response types to have the serialization code generated:
[JsonSerializable(typeof(APIGatewayHttpApiV2ProxyRequest))]
[JsonSerializable(typeof(APIGatewayHttpApiV2ProxyResponse))]
public partial class HttpApiJsonSerializerContext : JsonSerializerContext
{
}
To register the source generator for serialization use the LambdaSerializer
attribute
passing in the SourceGeneratorLambdaJsonSerializer
type along with the custom context
type (i.e. HttpApiJsonSerializerContext
) as the generic parameter.
[assembly: LambdaSerializer(
typeof(SourceGeneratorLambdaJsonSerializer
<APIGatewayExampleImage.HttpApiJsonSerializerContext>))]
Customizing serialization options
Both DefaultLambdaJsonSerializer
and SourceGeneratorLambdaJsonSerializer
construct an
instance of JsonSerializerOptions
that is used to customize the serialization and deserialization
of the Lambda JSON events. For example adding special converters and naming policies.
To further customize the JsonSerializerOptions
create a new type extending from extend
either DefaultLambdaJsonSerializer
or SourceGeneratorLambdaJsonSerializer
and pass
in an Action
customizer to the base constructor. Then register the new type as the
serializer using the LambdaSerializer
attribute. Below is an example of a custom serializer.
public class CustomLambdaSerializer : DefaultLambdaJsonSerializer
{
public CustomLambdaSerializer()
: base(CreateCustomizer())
{ }
private static Action<JsonSerializerOptions> CreateCustomizer()
{
return (JsonSerializerOptions options) =>
{
// Customize options
};
}
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp3.1 is compatible. |
-
.NETCoreApp 3.1
- Amazon.Lambda.Core (>= 2.3.0)
-
net6.0
- Amazon.Lambda.Core (>= 2.3.0)
-
net8.0
- Amazon.Lambda.Core (>= 2.3.0)
NuGet packages (27)
Showing the top 5 NuGet packages that depend on Amazon.Lambda.Serialization.SystemTextJson:
Package | Downloads |
---|---|
Amazon.Lambda.AspNetCoreServer
Amazon.Lambda.AspNetCoreServer makes it easy to run ASP.NET Core Web API applications as AWS Lambda functions. |
|
AWS.Lambda.Powertools.Logging
Powertools for AWS Lambda (.NET) - Logging package. |
|
AWS.Lambda.Powertools.Tracing
Powertools for AWS Lambda (.NET) - Tracing package. |
|
Kralizek.Lambda.Template
A structured template to create AWS Lambda in C#. It supports Logging, Dependency Injection and Configuration like ASP.NET Core projects do. |
|
LambdaSharp
Serverless .NET for AWS - Lambda Library |
GitHub repositories (17)
Showing the top 5 popular GitHub repositories that depend on Amazon.Lambda.Serialization.SystemTextJson:
Repository | Stars |
---|---|
mongodb/mongo-csharp-driver
The Official C# .NET Driver for MongoDB
|
|
aws/aws-sdk-net
The official AWS SDK for .NET. For more information on the AWS SDK for .NET, see our web site:
|
|
aws/aws-lambda-dotnet
Libraries, samples and tools to help .NET Core developers develop AWS Lambda functions.
|
|
TelegramBots/Telegram.Bot.Examples
Examples for the Telegram.Bot C# Library
|
|
mcneel/rhino-developer-samples
Rhino and Grasshopper developer sample code
|
Version | Downloads | Last updated |
---|---|---|
2.4.4 | 195,998 | 10/23/2024 |
2.4.3 | 2,577,091 | 4/25/2024 |
2.4.2 | 441,929 | 4/5/2024 |
2.4.1 | 2,886,307 | 2/16/2024 |
2.4.0 | 2,981,537 | 10/26/2023 |
2.3.1 | 8,426,096 | 2/2/2023 |
2.3.0 | 12,077,425 | 3/23/2022 |
2.2.0 | 5,781,635 | 11/5/2021 |
2.1.0 | 8,629,102 | 10/21/2020 |
2.0.2 | 594,549 | 9/16/2020 |
2.0.1 | 2,399,770 | 5/4/2020 |
2.0.0 | 1,391,054 | 4/28/2020 |
1.0.0 | 698,983 | 3/31/2020 |