您好,登錄后才能下訂單哦!
這篇文章主要介紹了從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 約束:
使DI容器只能構(gòu)建一次。
避免產(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í)!
免責(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)容。