­

ASP.NET Core 3.0 遷移避坑指南

  • 2019 年 10 月 3 日
  • 筆記

一.前言

.NET Core 3.0將會在 .NET Conf 大會上正式發布,截止今日發布了9個預覽版,改動也是不少,由於沒有持續關注,今天將前面開源的動態WebApi項目遷移到.NET Core 3.0還花了不少時間踩坑,給大家分享一下我在遷移過程中遇到的坑。遷移的版本是當前Release最新版本 .NET Core 2.2 到 .NET Core 3.0 Preview 9。

二.ASP.NET Core 項目遷移

官方遷移文檔:從 ASP.NET Core 2.2 遷移到3.0 ,這個官方文檔比較詳細,但是有一些東西裡面並沒有寫。

1.更改框架版本

將 TargetFramework 版本改為 netcoreapp3.0

1568095449709

2.移除Nuget包

移除下圖 Nuget 包

1568095550898

將其餘 Nuget 包更新到支援 .NET Core 3.0 版本

3.Program更改

    public class Program      {          public static void Main(string[] args)          {              CreateHostBuilder(args).Build().Run();          }            public static IHostBuilder CreateHostBuilder(string[] args) =>              Host.CreateDefaultBuilder(args)                  .ConfigureWebHostDefaults(webBuilder =>                  {                      webBuilder.UseStartup<Startup>();                  });      }

1568095685774

4.Startup更改

ConfigureServices 方法:

  1. services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2); 改為 services.AddControllers()(WebApi) / services.AddControllersWithViews();(MVC)

1568096481645

Configure 方法:

  1. 該方法里獲取Host環境資訊介面類型,IHostingEnvironment改為 IWebHostEnvironment

    1568096459106

  2. app.UseMVc 改為:

WebApi:

            app.UseRouting();                app.UseAuthorization();                app.UseEndpoints(endpoints =>              {                  endpoints.MapControllers();              });

MVC:

            app.UseRouting();                app.UseAuthorization();                app.UseEndpoints(endpoints =>              {                  endpoints.MapControllerRoute(                      name: "default",                      pattern: "{controller=Home}/{action=Index}/{id?}");              });

關於Json組件

ASP.NET Core 3.0 默認移除了 Newtonsoft.Json ,使用了微軟自己實現的 System.Text.Json,如果要改為 Newtonsoft.Json ,那麼有以下兩步:

1.安裝Nuget包:

Install-Package Microsoft.AspNetCore.Mvc.NewtonsoftJson

2.註冊

services.AddControllers().AddNewtonsoftJson();

三.類庫(Class Library Net Standard 2.0)項目遷移

因為 ASP.NET Core 3.0 對元包機制的改動,現在不能通過nuget安裝 Microsoft.AspNetCore.All 或者 Microsoft.AspNetCore.App 3.0版本,以及他們包含的大多數Nuget包也不能通過nuget安裝了(沒有3.0對應的版本)。如果說還引用2.2版本的nuget包,那麼運行起來可能會出錯。元包被包含在了 .NET Core SDK中,這意味著如果我們的類庫項目依賴了 AspNetCore 相關組件,那麼將沒法繼續將項目目標框架設置為 .NET Standard 了,只能設置為.NET Core 3.0,因為 ASP.NET Core 3.0 only run on .NET Core

元包機制改動原因:https://github.com/aspnet/AspNetCore/issues/3608

1568097757661

1.更改框架版本

1568097890464

2.更新Nuget包

移除 Microsoft.AspNetCore.* 不具有 .NET Core 3.0 的版本,例如:

1568097911477

添加 FrameworkReference(不是 PackageReference) 引用:

1568097942488

三.結束

題外話:ASP.NET Core 直到2.2 是可以同時運行在 .NET Framework 和 .NET Core 中,但是從 ASP.NET Core 3.0 開始,將會只支援 .NET Core。

相關資料:A first look at changes coming in ASP.NET Core 3.0

上面說的改動,微軟官方都有解釋原因,其實是為了變得更好而改動,彌補以前的缺點,只不過對於用了這麼久的Core來說有點折騰,但是還是能接受,為了更好的 .NET Core。