Microsoft.AspNetCore.JsonPatch 10.0.0-preview.4.25258.110

About

Microsoft.AspNetCore.JsonPatch provides ASP.NET Core support for JSON PATCH requests.

How to Use

To use Microsoft.AspNetCore.JsonPatch, follow these steps:

Installation

dotnet add package Microsoft.AspNetCore.JsonPatch
dotnet add package Microsoft.AspNetCore.Mvc.NewtonsoftJson

Configuration

To enable JSON Patch support, call AddNewtonsoftJson in your ASP.NET Core app's Program.cs:

var builder = WebApplication.CreateBuilder(args);

builder.Services.AddControllers()
    .AddNewtonsoftJson();

Configure when using System.Text.Json

To add support for JSON Patch using Newtonsoft.Json while continuing to use System.Text.Json for other input and output formatters:

  1. Update your Program.cs with logic to construct a NewtonsoftJsonPatchInputFormatter:
    static NewtonsoftJsonPatchInputFormatter GetJsonPatchInputFormatter()
    {
        var builder = new ServiceCollection()
            .AddLogging()
            .AddMvc()
            .AddNewtonsoftJson()
            .Services.BuildServiceProvider();
    
        return builder
            .GetRequiredService<IOptions<MvcOptions>>()
            .Value
            .InputFormatters
            .OfType<NewtonsoftJsonPatchInputFormatter>()
            .First();
    }
    
  2. Configure the input formatter:
    var builder = WebApplication.CreateBuilder(args);
    
    builder.Services.AddControllers(options =>
    {
        options.InputFormatters.Insert(0, GetJsonPatchInputFormatter());
    });
    

Usage

To define an action method for a JSON Patch in an API controller:

  1. Annotate it with the HttpPatch attribute
  2. Accept a JsonPatchDocument<TModel>
  3. Call ApplyTo on the patch document to apply changes

For example:

[HttpPatch]
public IActionResult JsonPatchWithModelState(
    [FromBody] JsonPatchDocument<Customer> patchDoc)
{
    if (patchDoc is not null)
    {
        var customer = CreateCustomer();

        patchDoc.ApplyTo(customer, ModelState);

        if (!ModelState.IsValid)
        {
            return BadRequest(ModelState);
        }

        return new ObjectResult(customer);
    }
    else
    {
        return BadRequest(ModelState);
    }
}

In a real app, the code would retrieve the data from a store such as a database and update the database after applying the patch.

Additional Documentation

For additional documentation and examples, refer to the official documentation on JSON Patch in ASP.NET Core.

Feedback & Contributing

Microsoft.AspNetCore.JsonPatch is released as open-source under the MIT license. Bug reports and contributions are welcome at the GitHub repository.

Showing the top 20 packages that depend on Microsoft.AspNetCore.JsonPatch.

Packages Downloads
Microsoft.AspNetCore.All
Microsoft.AspNetCore.All
55
Microsoft.AspNetCore.All
Microsoft.AspNetCore.All
58
Microsoft.AspNetCore.All
Microsoft.AspNetCore.All
59
Microsoft.AspNetCore.All
Microsoft.AspNetCore.All
62
Microsoft.AspNetCore.All
Provides a default set of APIs for building an ASP.NET Core application, and also includes API for third-party integrations with ASP.NET Core. This package requires the ASP.NET Core runtime. This runtime is installed by the .NET Core SDK, or can be acquired separately using installers available at https://aka.ms/dotnet-download.
55
Microsoft.AspNetCore.All
Provides a default set of APIs for building an ASP.NET Core application, and also includes API for third-party integrations with ASP.NET Core. This package requires the ASP.NET Core runtime. This runtime is installed by the .NET Core SDK, or can be acquired separately using installers available at https://aka.ms/dotnet-download.
59
Microsoft.AspNetCore.All
Provides a default set of APIs for building an ASP.NET Core application, and also includes API for third-party integrations with ASP.NET Core. This package requires the ASP.NET Core runtime. This runtime is installed by the .NET Core SDK, or can be acquired separately using installers available at https://aka.ms/dotnet-download.
61
Microsoft.AspNetCore.All
Provides a default set of APIs for building an ASP.NET Core application, and also includes API for third-party integrations with ASP.NET Core. This package requires the ASP.NET Core runtime. This runtime is installed by the .NET Core SDK, or can be acquired separately using installers available at https://aka.ms/dotnet-download.
62
Microsoft.AspNetCore.All
Provides a default set of APIs for building an ASP.NET Core application, and also includes API for third-party integrations with ASP.NET Core. This package requires the ASP.NET Core runtime. This runtime is installed by the .NET Core SDK, or can be acquired separately using installers available at https://aka.ms/dotnet-download.
68
Microsoft.AspNetCore.App
Provides a default set of APIs for building an ASP.NET Core application. This package requires the ASP.NET Core runtime. This runtime is installed by the .NET Core SDK, or can be acquired separately using installers available at https://aka.ms/dotnet-download.
57
Microsoft.AspNetCore.App
Provides a default set of APIs for building an ASP.NET Core application. This package requires the ASP.NET Core runtime. This runtime is installed by the .NET Core SDK, or can be acquired separately using installers available at https://aka.ms/dotnet-download.
61
Microsoft.AspNetCore.App
Provides a default set of APIs for building an ASP.NET Core application. This package requires the ASP.NET Core runtime. This runtime is installed by the .NET Core SDK, or can be acquired separately using installers available at https://aka.ms/dotnet-download.
62
Microsoft.AspNetCore.App
Provides a default set of APIs for building an ASP.NET Core application. This package requires the ASP.NET Core runtime. This runtime is installed by the .NET Core SDK, or can be acquired separately using installers available at https://aka.ms/dotnet-download.
78
Microsoft.AspNetCore.App
Provides a default set of APIs for building an ASP.NET Core application. This package requires the ASP.NET Core runtime. This runtime is installed by the .NET Core SDK, or can be acquired separately using installers available at https://aka.ms/dotnet-download.
83
Microsoft.AspNetCore.App
Provides a default set of APIs for building an ASP.NET Core application. This package requires the ASP.NET Core runtime. This runtime is installed by the .NET Core SDK, or can be acquired separately using installers available at https://aka.ms/dotnet-download. This package was built from the source at: https://github.com/aspnet/Universe/tree/1016eae4004686f7fdad13f5c329f63bbae1f3a1
73
Microsoft.AspNetCore.App
Provides a default set of APIs for building an ASP.NET Core application. This package requires the ASP.NET Core runtime. This runtime is installed by the .NET Core SDK, or can be acquired separately using installers available at https://aka.ms/dotnet-download. This package was built from the source at: https://github.com/aspnet/Universe/tree/244e037a222a7cd0a17feafb7f3a625fde40de97
52
Microsoft.AspNetCore.Mvc.NewtonsoftJson
ASP.NET Core MVC features that use Newtonsoft.Json. Includes input and output formatters for JSON and JSON PATCH. This package was built from the source code at https://github.com/aspnet/AspNetCore/tree/844a82e37cae48af2ab2ee4f39b41283e6bb4f0e
10,322

.NET Framework 4.6.2

.NET 10.0

.NET Standard 2.0

Version Downloads Last updated
10.0.0-preview.4.25258.110 2 05/25/2025
10.0.0-preview.3.25172.1 14 04/15/2025
10.0.0-preview.2.25164.1 9 03/21/2025
10.0.0-preview.1.25120.3 8 02/27/2025
9.0.5 1 05/25/2025
9.0.4 7 04/11/2025
9.0.3 8 03/14/2025
9.0.2 8 02/17/2025
9.0.1 11 01/16/2025
9.0.0 14 11/15/2024
9.0.0-rc.2.24474.3 15 10/14/2024
9.0.0-rc.1.24452.1 17 09/11/2024
9.0.0-preview.7.24406.2 16 08/13/2024
9.0.0-preview.6.24328.4 18 07/10/2024
9.0.0-preview.5.24306.11 20 06/14/2024
9.0.0-preview.4.24267.6 16 05/22/2024
9.0.0-preview.3.24172.13 18 04/17/2024
9.0.0-preview.2.24128.4 21 03/15/2024
9.0.0-preview.1.24081.5 20 02/20/2024
8.0.16 1 05/25/2025
8.0.15 7 04/11/2025
8.0.14 7 03/14/2025
8.0.13 13 02/17/2025
8.0.12 15 01/16/2025
8.0.11 14 11/15/2024
8.0.10 14 10/13/2024
8.0.8 14 08/13/2024
8.0.7 21 07/14/2024
8.0.6 16 05/28/2024
8.0.5 18 05/16/2024
8.0.4 20 04/16/2024
8.0.3 20 03/12/2024
8.0.2 17 02/18/2024
8.0.1 23 02/18/2024
8.0.0 30 11/14/2023
8.0.0-rc.2.23480.2 24 10/22/2023
8.0.0-rc.1.23421.29 25 09/17/2023
8.0.0-preview.7.23375.9 31 08/23/2023
8.0.0-preview.6.23329.11 27 09/26/2023
8.0.0-preview.5.23302.2 32 06/16/2023
8.0.0-preview.4.23260.4 28 05/26/2023
8.0.0-preview.3.23177.8 35 06/16/2023
8.0.0-preview.2.23153.2 28 06/16/2023
8.0.0-preview.1.23112.2 29 03/28/2023
7.0.20 17 05/28/2024
7.0.19 25 05/16/2024
7.0.18 27 04/16/2024
7.0.17 18 03/12/2024
7.0.16 17 02/19/2024
7.0.15 20 02/18/2024
7.0.14 26 11/14/2023
7.0.13 24 10/26/2023
7.0.12 21 10/13/2023
7.0.11 22 09/17/2023
7.0.10 25 09/27/2023
7.0.9 24 09/27/2023
7.0.8 30 07/12/2023
7.0.7 19 06/16/2023
7.0.5 26 06/16/2023
7.0.4 21 03/28/2023
7.0.3 27 03/28/2023
7.0.2 21 03/28/2023
7.0.1 20 03/28/2023
7.0.0 49 01/10/2023
7.0.0-rc.2.22476.2 37 10/17/2022
7.0.0-rc.1.22427.2 35 09/21/2022
7.0.0-preview.7.22376.6 32 09/21/2022
7.0.0-preview.6.22330.3 26 10/17/2022
7.0.0-preview.5.22303.8 29 09/21/2022
7.0.0-preview.4.22251.1 28 09/24/2022
7.0.0-preview.3.22178.4 28 09/21/2022
7.0.0-preview.2.22153.2 36 09/24/2022
7.0.0-preview.1.22109.13 39 09/21/2022
6.0.36 14 11/15/2024
6.0.35 12 10/14/2024
6.0.33 15 08/13/2024
6.0.32 16 07/18/2024
6.0.31 16 05/28/2024
6.0.30 20 05/16/2024
6.0.29 15 04/16/2024
6.0.28 18 03/12/2024
6.0.27 22 02/18/2024
6.0.26 20 02/18/2024
6.0.25 26 11/14/2023
6.0.24 16 10/26/2023
6.0.23 18 10/13/2023
6.0.22 15 09/17/2023
6.0.21 18 09/27/2023
6.0.20 22 10/02/2023
6.0.19 27 08/11/2023
6.0.18 22 06/16/2023
6.0.16 22 06/16/2023
6.0.15 29 03/28/2023
6.0.14 23 03/28/2023
6.0.13 26 03/28/2023
6.0.12 36 06/16/2023
6.0.11 21 03/28/2023
6.0.10 27 10/17/2022
6.0.9 22 09/22/2022
6.0.8 28 09/21/2022
6.0.7 39 09/22/2022
6.0.6 42 09/23/2022
6.0.5 20 10/17/2022
6.0.4 74 07/10/2022
6.0.3 25 08/21/2022
6.0.2 21 09/21/2022
6.0.1 25 10/17/2022
6.0.0 32 09/21/2022
6.0.0-rc.2.21480.10 24 10/17/2022
6.0.0-rc.1.21452.15 85 10/17/2022
6.0.0-preview.7.21378.6 31 09/26/2022
6.0.0-preview.6.21355.2 72 10/17/2022
6.0.0-preview.5.21301.17 28 09/22/2022
6.0.0-preview.4.21253.5 36 09/21/2022
6.0.0-preview.3.21201.13 34 10/17/2022
6.0.0-preview.2.21154.6 32 09/22/2022
6.0.0-preview.1.21103.6 43 09/21/2022
5.0.17 22 09/22/2022
5.0.16 75 09/21/2022
5.0.15 27 10/17/2022
5.0.14 21 06/27/2022
5.0.13 28 07/08/2022
5.0.12 23 07/25/2022
5.0.11 28 09/23/2022
5.0.10 23 10/17/2022
5.0.9 29 08/27/2022
5.0.8 29 07/15/2022
5.0.7 30 09/21/2022
5.0.6 55 10/17/2022
5.0.5 25 08/31/2022
5.0.4 27 09/21/2022
5.0.3 26 09/21/2022
5.0.2 30 10/17/2022
5.0.1 29 09/24/2022
5.0.0 37 06/30/2022
5.0.0-rc.2.20475.17 43 09/26/2022
5.0.0-rc.1.20451.17 38 09/21/2022
5.0.0-preview.8.20414.8 36 10/17/2022
5.0.0-preview.7.20365.19 34 09/22/2022
5.0.0-preview.6.20312.15 28 09/22/2022
5.0.0-preview.5.20279.2 74 07/05/2022
5.0.0-preview.4.20257.10 32 10/17/2022
5.0.0-preview.3.20215.14 29 10/17/2022
5.0.0-preview.2.20167.3 31 09/21/2022
5.0.0-preview.1.20124.5 28 09/21/2022
3.1.32 23 03/28/2023
3.1.31 26 03/28/2023
3.1.30 17 10/17/2022
3.1.29 28 09/25/2022
3.1.28 19 09/21/2022
3.1.27 25 09/23/2022
3.1.26 22 07/29/2022
3.1.25 26 09/21/2022
3.1.24 28 09/10/2022
3.1.23 24 10/17/2022
3.1.22 46 09/22/2022
3.1.21 27 06/28/2022
3.1.20 64 09/25/2022
3.1.19 49 07/05/2022
3.1.18 54 07/25/2022
3.1.17 27 09/22/2022
3.1.16 27 10/17/2022
3.1.15 33 07/18/2022
3.1.14 22 08/06/2022
3.1.13 24 08/10/2022
3.1.12 31 09/24/2022
3.1.11 29 09/21/2022
3.1.10 29 10/17/2022
3.1.9 27 07/30/2022
3.1.8 26 09/22/2022
3.1.7 61 09/23/2022
3.1.6 52 07/05/2022
3.1.5 10,335 06/27/2022
3.1.4 33 09/23/2022
3.1.3 28 09/21/2022
3.1.2 27 09/21/2022
3.1.1 24 09/21/2022
3.1.0 50 09/21/2022
3.1.0-preview3.19555.2 41 10/15/2022
3.1.0-preview2.19528.8 30 09/25/2022
3.1.0-preview1.19508.20 57 07/02/2022
3.0.3 81 10/17/2022
3.0.2 51 07/14/2022
3.0.0 36 07/12/2022
3.0.0-rc1.19457.4 26 09/23/2022
3.0.0-preview9.19424.4 29 10/17/2022
3.0.0-preview8.19405.7 66 09/21/2022
3.0.0-preview7.19365.7 51 10/19/2022
3.0.0-preview6.19307.2 26 09/25/2022
3.0.0-preview5-19227-01 28 09/24/2022
3.0.0-preview4-19216-03 41 09/21/2022
3.0.0-preview3-19153-02 51 09/25/2022
3.0.0-preview-19075-0444 30 10/19/2022
3.0.0-preview-18579-0056 35 07/29/2022
2.3.0 10 01/16/2025
2.2.0 30 07/15/2022
2.2.0-preview3-35497 78 09/21/2022
2.2.0-preview2-35157 30 07/25/2022
2.2.0-preview1-35029 62 09/21/2022
2.1.1 31 09/26/2022
2.1.0 24 06/27/2022
2.1.0-rc1-final 29 07/29/2022
2.1.0-preview2-final 34 09/21/2022
2.1.0-preview1-final 32 09/21/2022
2.0.0 26 10/19/2022
2.0.0-preview2-final 32 09/22/2022
2.0.0-preview1-final 31 09/21/2022
1.1.2 25 09/21/2022
1.1.1 23 10/19/2022
1.1.0 25 10/19/2022
1.1.0-preview1-final 30 09/22/2022
1.0.0 25 07/20/2022
1.0.0-rc2-final 68 10/19/2022