--- title: Migrate from ASP.NET Core 3.0 to 3.1 author: scottaddie description: Learn how to migrate an ASP.NET Core 3.0 project to ASP.NET Core 3.1. ms.author: scaddie ms.custom: mvc ms.date: 12/03/2019 uid: migration/30-to-31 --- # Migrate from ASP.NET Core 3.0 to 3.1 By [Scott Addie](https://github.com/scottaddie) This article explains how to update an existing ASP.NET Core 3.0 project to ASP.NET Core 3.1. ## Prerequisites # [Visual Studio](#tab/visual-studio) [!INCLUDE[](~/includes/net-core-prereqs-vs-3.1.md)] # [Visual Studio Code](#tab/visual-studio-code) [!INCLUDE[](~/includes/net-core-prereqs-vsc-3.1.md)] # [Visual Studio for Mac](#tab/visual-studio-mac) [!INCLUDE[](~/includes/net-core-prereqs-mac-3.1.md)] --- ## Update .NET Core SDK version in global.json If you rely upon a [global.json](/dotnet/core/tools/global-json) file to target a specific .NET Core SDK version, update the `version` property to the 3.1 SDK version that's installed. For example: ```diff { "sdk": { - "version": "3.0.101" + "version": "3.1.100" } } ``` ## Update the target framework In the project file, update the [Target Framework Moniker (TFM)](/dotnet/standard/frameworks) to `netcoreapp3.1`: ```diff - netcoreapp3.0 + netcoreapp3.1 ``` ## Update package references In the project file, update each `Microsoft.AspNetCore.*` package reference's `Version` attribute to 3.1.0 or later. For example: ```diff - - + + ``` ## Update Docker images For apps using Docker, use a base image that includes ASP.NET Core 3.1. For example: ```console docker pull mcr.microsoft.com/dotnet/core/aspnet:3.1 ``` ## React to SameSite cookie changes The `SameSite` attribute implementations for HTTP cookies changed between ASP.NET Core 3.0 and 3.1. For actions to be taken, see the following resources: * * [aspnet/Announcements#390](https://github.com/aspnet/Announcements/issues/390) * [Upcoming SameSite cookie changes in ASP.NET and ASP.NET Core](https://devblogs.microsoft.com/aspnet/upcoming-samesite-cookie-changes-in-asp-net-and-asp-net-core/) ## Review breaking changes Review 3.0-to-3.1 breaking changes across .NET Core, ASP.NET Core, and Entity Framework Core at [Breaking changes for migration from version 3.0 to 3.1](/dotnet/core/compatibility/3.0-3.1). ## Optional changes The following changes are optional. ### Use the Component Tag Helper ASP.NET Core 3.1 introduces a `Component` Tag Helper. The Tag Helper can replace the `RenderComponentAsync` HTML helper method in a Blazor project. For example: ```diff - @(await Html.RenderComponentAsync(RenderMode.ServerPrerendered, new { IncrementAmount = 10 })) + ``` For more information, see [Integrate components into Razor Pages and MVC apps](/aspnet/core/blazor/components?view=aspnetcore-3.1#integrate-components-into-razor-pages-and-mvc-apps).