Alphacloud.MessagePack.AspNetCore.Formatters
5.0.0-alpha0020
dotnet add package Alphacloud.MessagePack.AspNetCore.Formatters --version 5.0.0-alpha0020
NuGet\Install-Package Alphacloud.MessagePack.AspNetCore.Formatters -Version 5.0.0-alpha0020
<PackageReference Include="Alphacloud.MessagePack.AspNetCore.Formatters" Version="5.0.0-alpha0020" />
paket add Alphacloud.MessagePack.AspNetCore.Formatters --version 5.0.0-alpha0020
#r "nuget: Alphacloud.MessagePack.AspNetCore.Formatters, 5.0.0-alpha0020"
// Install Alphacloud.MessagePack.AspNetCore.Formatters as a Cake Addin #addin nuget:?package=Alphacloud.MessagePack.AspNetCore.Formatters&version=5.0.0-alpha0020&prerelease // Install Alphacloud.MessagePack.AspNetCore.Formatters as a Cake Tool #tool nuget:?package=Alphacloud.MessagePack.AspNetCore.Formatters&version=5.0.0-alpha0020&prerelease
MessagePack Formatters for ASP.NET Core MVC and HttpClient
Allows to use MessagePack format with ASP.NET Core MVC. If multiple formatters are configured, content negotiation is used to determine which formatter to use.
This library leverages MessagePack-CSharp library by Yoshifumi Kawai (a.k.a. neuecc).
Build status
Stable | Pre-release | |
---|---|---|
Build | ||
NuGet ASP.NET Core MVC formatters | ||
NuGet MediaTypeFormatter for HttpClient |
Packages
ASP.NET Core MVC formatters
Installation
Install-Packagge Alphacloud.MessagePack.AspNetCore.Formatters
Features
- Input formatter (decode MessagePack payload).
- Output formatter (encode MessagePack payload).
- Source link support (source code on demand in debugger).
Usage
Default configuration
Default configuration uses application/x-msgpack
as media typeidentificator, msgpack
as file name extension and ContractlessStandardResolver
.
Add services.AddMessagePack();
call to your Startup.cs / ConfigureServices
public void ConfigureServices(IServiceCollection services)
{
services.AddMessagePack();
// ...
}
MVC Core (ASP.NET Core 2.x)
When using minimal MVC configuration (e.g. in WebAPI service) only base services are added by default. You are responsible for configuring each of the service you are going to use.
Note: order of formatters is important - in the example below Json will be default serializer, unless MVC is configured to reject requests with unsupported media type.
public void ConfigureServices(IServiceCollection services)
{
services.AddMvcCore(options =>
{
// ...
})
.AddDataAnnotations()
.AddJsonOptions(options =>
{
options.SerializerSettings.Culture = CultureInfo.InvariantCulture;
options.SerializerSettings.Formatting = Formatting.None;
})
.AddFormatterMappings()
.AddJsonFormatters()
.AddXmlSerializerFormatters()
.AddMsgPackFormatters()
;
}
Custom configuration
Default configuration can be changed by providing callback to AddMessagePack
method.
Available settings:
MediaTypes
- allows to specify additional media handled by MessagePack formatters. Default isapplication/x-msgpack
.FormatterResolver
- allows to customize serialization, see MsgPack object serialization for details.FileExtensions
- allows to specify reponse format URL mapping. Default ismsgpack
. See sample project or Microsoft Docs for more information.Compression
- allows to specify LZ4 compression for messages.UseOldSpecification
- write message using old specification compatibility mode. Reading will support both old and new specifications. See Message Pack format specification.OmitAssemblyVersion
- don't write assembly version and public key token when using typeless formatter.AllowAssemblyVersionMismatch
- allows assembly version mistmatch when loading types during deserialization.
services.AddMessagePack(opt =>
{
opt.MediaTypes.Clear();
opt.MediaTypes.Add("application/x-messagepack");
opt.FileExtensions.Add("messagepack");
opt.FormatterResolver = MessagePack.Resolvers.ContractlessStandardResolverAllowPrivate.Instance;
})
MediaTypeFormatter for HttpClient
Microsoft.AspNet.WebApi.Client package contains adds support for formatting and content negotiation to System.Net.Http.
It allows to add custom content serializers by extending MediaTypeFormatter
class.
Installation
Install-Package Alphacloud.MessagePack.HttpFormatter
Usage
Sending request
Library contains two extension methods PostAsMsgPackAsync
and PutAsMsgPackAsync
. To serialize payload ContractlessStandardResolver
is used, which gives a JSON-like experience.
var response = await httpClient.PostAsMsgPackAsync(uri, payload, cancellationToken).ConfigureAwait(false);
Reading response
To deserialize Msgpack response, formatter must be added to formatters
collection passed to ReadAsAsync
extension method.
This is recommeded method as it enables content negotiation.
var res = await response.Content.ReadAsAsync<TestModel>(_formatters, CancellationToken.None);
if you are expecting only MsgPack content, use MsgPackHttpContentExtensions.ReadMsgPackAsAsync()
for HttpContent
.
Samples
Sample application is located at src/samples/NetCoreWebApi
.
Sample Postman requests can be found at src/samples/MessagePack.postman_collection.json
. To post MessagePack content, use SingleModel.msgpack
located under src/samples
.
References
- MessagePack format https://msgpack.org/index.html
- MessagePack-CSharp https://github.com/neuecc/MessagePack-CSharp
- AddMVC vs AddMvcCore
- Content negotiation in ASP.NET Core MVC https://code-maze.com/content-negotiation-dotnet-core/
- Microsoft.AspNet.WebApi.Client https://www.nuget.org/packages/Microsoft.AspNet.WebApi.Client/
- Source Link - https://github.com/ctaggart/SourceLink
- Postman https://www.getpostman.com/downloads/
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | 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 is compatible. 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. |
-
net6.0
- JetBrains.Annotations (>= 2023.3.0)
- MessagePack (>= 2.5.140 && < 3.0.0)
-
net7.0
- JetBrains.Annotations (>= 2023.3.0)
- MessagePack (>= 2.5.140 && < 3.0.0)
-
net8.0
- JetBrains.Annotations (>= 2023.3.0)
- MessagePack (>= 2.5.140 && < 3.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
5.0.0-alpha0020 | 121 | 3/14/2024 |
5.0.0-alpha0019 | 104 | 3/8/2024 |
5.0.0-alpha0013 | 237 | 4/1/2023 |
5.0.0-alpha0012 | 120 | 3/31/2023 |
4.1.0 | 53,567 | 3/31/2023 |
4.0.0 | 13,328 | 5/30/2022 |
4.0.0-beta0001 | 165 | 5/27/2022 |
4.0.0-alpha0025 | 154 | 5/27/2022 |
4.0.0-alpha0021 | 157 | 5/26/2022 |
3.2.0 | 11,092 | 8/1/2021 |
3.2.0-alpha0018 | 270 | 8/1/2021 |
3.2.0-alpha0017 | 277 | 8/1/2021 |
3.2.0-alpha0016 | 273 | 8/1/2021 |
3.2.0-alpha0010 | 214 | 6/20/2021 |
3.2.0-alpha0008 | 230 | 4/30/2021 |
3.2.0-alpha0007 | 268 | 4/19/2021 |
3.2.0-alpha0006 | 258 | 4/19/2021 |
3.2.0-alpha0001 | 217 | 1/29/2021 |
3.1.0 | 5,288 | 1/29/2021 |
3.1.0-beta0001 | 206 | 1/29/2021 |
3.1.0-alpha0003 | 233 | 1/28/2021 |
3.1.0-alpha0002 | 285 | 12/27/2020 |
3.1.0-alpha0001 | 273 | 12/27/2020 |
3.0.0 | 591 | 12/6/2020 |
3.0.0-beta0001 | 338 | 12/5/2020 |
2.3.0-alpha0010 | 366 | 12/5/2020 |
2.3.0-alpha0001 | 330 | 10/21/2020 |
2.2.0 | 2,101 | 10/21/2020 |
2.2.0-beta0001 | 348 | 10/21/2020 |
2.2.0-alpha0045 | 332 | 10/21/2020 |
2.2.0-alpha0025 | 401 | 2/26/2020 |
2.2.0-alpha0024 | 474 | 2/8/2020 |
2.2.0-alpha0023 | 449 | 2/8/2020 |
2.2.0-alpha0020 | 357 | 8/19/2020 |
2.2.0-alpha0019 | 399 | 6/22/2020 |
2.2.0-alpha0017 | 400 | 5/20/2020 |
2.2.0-alpha0016 | 400 | 5/20/2020 |
2.2.0-alpha0015 | 352 | 5/19/2020 |
2.2.0-alpha0001 | 362 | 3/1/2020 |
2.1.3 | 2,393 | 8/19/2020 |
2.1.3-beta0001 | 367 | 8/19/2020 |
2.1.2 | 1,129 | 5/29/2020 |
2.1.2-beta0001 | 371 | 5/29/2020 |
2.1.1 | 1,260 | 3/1/2020 |
2.1.1-beta0001 | 403 | 3/1/2020 |
2.1.0 | 758 | 2/8/2020 |
2.1.0-beta0001 | 436 | 2/8/2020 |
2.1.0-alpha0004 | 457 | 2/8/2020 |
2.1.0-alpha0002 | 475 | 2/8/2020 |
2.0.0 | 1,215 | 1/14/2020 |
2.0.0-beta0001 | 383 | 1/14/2020 |
2.0.0-alpha0003 | 493 | 1/12/2020 |
1.1.0-alpha0002 | 391 | 11/18/2019 |
1.0.0 | 713 | 11/18/2019 |
1.0.0-beta0001 | 403 | 11/18/2019 |
0.3.0-alpha0011 | 392 | 11/9/2019 |
0.3.0-alpha0005 | 447 | 7/10/2019 |
0.3.0-alpha0002 | 423 | 7/6/2019 |
0.3.0-alpha0001 | 445 | 5/8/2019 |
0.2.0 | 1,736 | 2/5/2019 |
0.2.0-alpha0019 | 531 | 2/4/2019 |
0.2.0-alpha0018 | 525 | 2/4/2019 |
0.2.0-alpha0016 | 705 | 1/28/2019 |
0.2.0-alpha0013 | 713 | 1/27/2019 |
0.2.0-alpha0001 | 698 | 8/19/2018 |
0.1.0 | 1,010 | 8/19/2018 |
0.1.0-rc0024 | 695 | 8/19/2018 |
0.1.0-beta0001 | 721 | 8/19/2018 |