溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

從ASP.NET Core2.2到3.0你會遇到什么問題

發(fā)布時間:2021-08-05 09:54:29 來源:億速云 閱讀:127 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要介紹了從ASP.NET Core2.2到3.0你會遇到什么問題,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

我遇到的問題

ASP.NET Core2.0時代,若要為項目添加 EF Core 支持,需要安裝相應(yīng)的數(shù)據(jù)庫驅(qū)動包。 教程中使用 SQL Server,相關(guān)驅(qū)動包Microsoft.EntityFrameworkCore.SqlServer。 此包包含在 Microsoft.AspNetCore.App 元包中,因此,如果應(yīng)用具有對 Microsoft.AspNetCore.App 包的包引用,則無需引用該包。而2.0中的模板項目會自動為我們加載Mcrosoft.AspNetCore.App這個包的。但是3.0中沒有了這個Mcrosoft.AspNetCore.App這個包,模塊化的更徹底了!所需要的EF相關(guān)的包需要你自己來進行引用。

2.0升3.0升級指南

就著今天遇到的問題,所以我整理下ASP.NET Core從2.0升級3.0的一個升級指南,希望對大伙有所幫助,當(dāng)然大伙也可以直接閱讀微軟的官方文檔進行查看。但是我在閱讀官方說明的時候,總感覺翻譯的不是很準(zhǔn)確,讀起來很拗口,所以這里我是自己的理解對官方文檔的一個補充。

更新項目文件

設(shè)置TargetFramework到netcoreapp3.0:

<TargetFramework>netcoreapp3.0</TargetFramework>

刪除Microsoft.AspNetCore.All或Microsoft.AspNetCore.App元包的任何<PackageReference>。

將<PackageReference>元素中剩余的Microsoft.AspNetCore.*程序包更新到當(dāng)前的預(yù)覽版中 (例如,3.0.0-preview3.19128.7)。

如果沒有對應(yīng)的 3.0 版本的包,則說明包可能會在 3.0 中棄用。 其中許多之前都屬于Microsoft.AspNetCore.App并且不需要單獨引用的包,如上面我遇到的問題,關(guān)于SQL Server的EF相關(guān)的包。 具體的不再在 3.0 中生成的包的列表,請參閱aspnet/AspNetCore #3756。

某些程序集已從2.x和3.0之間的Microsoft.aspnetcore.app中刪除。如果您正在使用aspnet/AspNetCore #3755中列出的包中的API,則可能需要單獨添加到。

例如,Microsoft.EntityFrameworkCore和System.Data.SqlClient不再屬于Microsoft.AspNetCore.App得一部分。 Microsoft.aspnetcore.app中的程序集列表尚未定稿,將在3.0 RTM之前更改。

添加Json.NET 支持。

項目默認(rèn)為 ASP.NET Core 3.0 或更高版本設(shè)置為進程內(nèi)承載模型。 當(dāng)然,如果其值為InProcess您還可以通過刪除<AspNetCoreHostingModel>元素,來進行修改。

作為提高ASP.NET Core 共享的框架工作的一部分,Json.NET已從 ASP.NET Core 共享框架中刪除。

若要在 ASP.NET Core 3.0 項目中使用 Json.NET:

添加到包引用Microsoft.AspNetCore.Mvc.NewtonsoftJson

更新ConfigureServices調(diào)用AddNewtonsoftJson()。

services.AddMvc()
 .AddNewtonsoftJson();

Newtonsoft 的個性化設(shè)置可以設(shè)置為AddNewtonsoftJson:

services.AddMvc()
 .AddNewtonsoftJson(options =>
   options.SerializerSettings.ContractResolver =
    new CamelCasePropertyNamesContractResolver());

HostBuilder 替換 WebHostBuilder

使用 ASP.NET Core 3.0 模板泛型宿主。 早期版本使用Web 主機。 下面的代碼顯示了生成 ASP.NET Core 3.0 模板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>();
   });
}

下面的代碼演示模板生成 ASP.NET Core 2.2Program類:

public class Program
{
 public static void Main(string[] args)
 {
  CreateWebHostBuilder(args).Build().Run();
 }

 public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
  WebHost.CreateDefaultBuilder(args)
   .UseStartup<Startup>();
}

IWebHostBuilder 將保留在 3.0,是一種webBuilder上面的代碼示例所示。 WebHostBuilder 將在未來版本中棄用并替換為HostBuilder。

從WebHostBuilder到HostBuilder最顯著的變化是依賴關(guān)系注入 (DI)。 使用時HostBuilder,只能將IConfiguration并IHostingEnvironment注入到Startup的構(gòu)造函數(shù)中。 HostBuilder DI 約束:

  1. 使DI容器只能構(gòu)建一次。

  2. 避免產(chǎn)生的對象生存期問題,例如解決多個單例實例。

更新 SignalR 代碼

如果您調(diào)用AddJsonProtocol,將其替換為AddNewtonsoftJsonProtocol。

以下示例顯示更改前后的服務(wù)器代碼:

services.AddSignalR(...)
  .AddJsonProtocol(...) // 2.2
services.AddSignalR(...)
  .AddNewtonsoftJsonProtocol(...) // 3.0

以下示例顯示更改前后的.NET客戶端代碼:

connection = new HubConnectionBuilder()
 .WithUrl(...)
 .AddJsonProtocol(...) // 2.2
 .Build()
connection = new HubConnectionBuilder()
 .WithUrl(...)
 .AddNewtonsoftJsonProtocol(...) // 3.0
 .Build()

選擇啟用運行時編譯

在 3.0 中,運行時編譯是可選的方案。 若要啟用運行時編譯,請參閱ASP.NET Core 中的 Razor 文件編譯。

總結(jié)

感覺微軟在努力實現(xiàn)ASP.NET Core的模塊化,減小各種依賴,讓包變得更小。同時ASP.NET Core也已經(jīng)很完善了,大伙是時候用起來ASP.NET Core了。另外需要說明的一點是,大伙如果是為了體驗ASP.NET Core3.0的話,現(xiàn)在就可以,如果是用在生產(chǎn)環(huán)境的話最好還是等待正式版的發(fā)布吧。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“從ASP.NET Core2.2到3.0你會遇到什么問題”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI