[翻譯]ASP.NET Core在 .NET 5 Preview 7的更新

HueiFeng發表於2020-07-22

.NET 5 Preview 7現在可以用了,可以進行評估了。這是此版本中的新增功能:

  • Blazor WebAssembly應用程式現在針對.NET 5
  • 更新了Blazor WebAssembly的除錯要求
  • Blazor的可訪問性改進
  • Blazor的效能改進
  • 證照認證效能改進
  • 傳送HTTP/2 PING幀
  • 支援Kestrel套接字傳輸中的其他終結點型別
  • Kestrel中的自定義標頭解碼
  • 其他小改進

Get started

要開始使用.NET 5 Preview 7中的ASP.NET Core,請安裝.NET 5 SDK
您需要使用的Visual Studio 2019 16.7 PreView 5或更新的版本來使用.NET 5 Preview 7. .NET 5也支援了最新的預覽Visual Studio中的Mac。要將.NET 5與Visual Studio Code一起使用,請安裝最新版本的C# extension

升級現有專案

要將現有的ASP.NET Core應用程式從.NET 5 Preview 6升級到.NET 5 Preview 7,請執行以下操作:

  • 將所有Microsoft.AspNetCore.* 軟體包引用更新為。5.0.0-preview.7.*
  • 將所有Microsoft.Extensions.* 程式包引用更新為。5.0.0-preview.7.*
  • 更新System.Net.Http.Json包引用。5.0.0-preview.7.*

請參閱.NET 5的ASP.NET Core 中重大更改的完整列表。

升級現有的Blazor WebAssembly專案

要升級現有的Blazor WebAssembly專案,請更新以下屬性:

<TargetFramework>netstandard2.1</TargetFramework>
<RazorLangVersoin>3.0</RazorLangVersion>

<TargetFramework>net5.0</TargetFramework>
<RuntimeIdentifier>browser-wasm</RuntimeIdentifier>
<UseBlazorWebAssembly>true</UseBlazorWebAssembly>

另外,請刪除對的所有包引用,因為不再需要它。Microsoft.AspNetCore.Components.WebAssembly.Build

什麼是新的?

Blazor WebAssembly應用程式現在針對.NET 5

Blazor WebAssembly 3.2應用程式只能訪問.NET Standard 2.1 API集。在此版本中,Blazor WebAssembly專案現在以.NET 5為目標,並且可以訪問更廣泛的API集。在.NET 5中實現對API的Blazor WebAssembly支援正在進行中,因此某些API可能會在執行時丟擲。如果您因缺乏對特定API的支援而受阻,我們很樂意收到您的來信。net5.0``PlatformNotSupportedException

更新了Blazor WebAssembly的除錯要求

要在Visual Studio Code中啟用Blazor WebAssembly應用程式的除錯,您以前需要安裝JavaScript Debugger(Nightly)擴充套件程式。不再需要這樣做,因為JavaScript偵錯程式擴充套件現已作為VS Code的一部分提供。如果您先前已安裝(Nightly)JavaScript偵錯程式擴充套件,則可以將其解除安裝。仍然需要通過Visual Studio Code設定啟用JavaScript偵錯程式的預覽版。

Blazor的可訪問性改進

InputBase現在開始派生的內建Blazor輸入元件會在驗證失敗時自動呈現aria-invalid

Blazor的效能改進

.NET 5中Blazor WebAssembly的主要投資領域之一是提高執行時效能。這是一個多方面的努力。以下是一些需要優化的高階區域:

  • .NET執行時執行
  • JSON序列化
  • JavaScript互操作
  • Blazor元件渲染

不斷改進.NET 5的Blazor WebAssembly執行時效能。此版本包含一些初步的效能改進,我們希望在以後的.NET 5更新中共享有關此效能工作結果的更多詳細資訊。

證照認證效能改進

我們在ASP.NET Core中為證照身份驗證新增了快取。快取證照驗證可以大大提高證照驗證的效能。我們的基準測試顯示,啟用快取後,每秒請求的速度提高了400%。
您無需對應用程式進行任何更改即可利用效能改進。預設情況下,快取處於開啟狀態。如果您願意,有一些選項可以調整或禁用快取。
在文件中找到有關ASP.NET Core 中的證照身份驗證的更多資訊。

傳送HTTP/2 PING幀

HTTP / 2具有用於傳送PING幀的機制,以確保空閒連線是否仍然有效。當使用長期閒置但只能間歇性地檢視活動的長壽命流(例如gRPC流)時,此功能特別有用。通過在上設定限制,我們增加了在Kestrel中傳送定期PING幀的功能KestrelServerOptions

public static IHostBuilder CreateHostBuilder(string[] args) =>
    Host.CreateDefaultBuilder(args)
        .ConfigureWebHostDefaults(webBuilder =>
        {
            webBuilder.ConfigureKestrel(options =>
            {
                options.Limits.Http2.KeepAlivePingInterval = TimeSpan.FromSeconds(10);
                options.Limits.Http2.KeepAlivePingTimeout = TimeSpan.FromSeconds(1);
            });
            webBuilder.UseStartup<Startup>();
        });

支援Kestrel套接字傳輸中的其他終結點型別

在Kestrel中引入的新API的基礎上,Kestrel中的套接字傳輸(預設)現在允許您繫結到現有檔案控制程式碼和Unix域套接字。支援繫結到現有檔案控制程式碼,從而可以使用現有的Systemd整合,而無需使用libuv傳輸。System.Net.Sockets

Kestrel中的自定義標頭解碼

我們新增了根據標題名稱指定用於解釋傳入標題的功能,而不是預設使用UTF-8。您可以將屬性設定為on,以指定要使用的編碼。System.Text.Encoding``RequestHeaderEncodingSelector``KestrelServerOptions

public static IHostBuilder CreateHostBuilder(string[] args) =>
    Host.CreateDefaultBuilder(args)
        .ConfigureWebHostDefaults(webBuilder =>
        {
            webBuilder.ConfigureKestrel(options =>
            {
                options.RequestHeaderEncodingSelector = encoding =>
                {
                    switch (encoding)
                    {
                        case "Host":
                            return System.Text.Encoding.Latin1;
                        default:
                            return System.Text.Encoding.UTF8;
                    }
                };
            });
            webBuilder.UseStartup<Startup>();
        });

其他改進

  • 對於預覽版7,我們已開始將可為空的註釋應用於ASP.NET Core程式集。我們打算在5.0版本期間對框架的大多數常見公共API表面進行註釋。
  • CompareAttribute 現在可以應用於“Razor Page”模型上的屬性。
  • 預設情況下,從主體繫結的引數和屬性被認為是必需的。
  • 我們已經開始將可為空的註釋應用於ASP.NET Core程式集。我們打算在.NET 5釋出期間對框架的大多數常見公共API表面進行註釋。
  • 現在,使用端點路由時的授權將接收HttpContext而不是端點例項。這允許授權中介軟體訪問通過類無法訪問的RouteData和屬性。可以使用從上下文中獲取端點。HttpContext``Endpoint``context.GetEndpoint()
  • 現在的預設格式預設為W3C格式。預設情況下,這使得ASP.NET Core中的分散式跟蹤支援可與更多框架互操作。System.Diagnostics.Activity
  • CompareAttribute 現在可以應用於“Razor Page”模型上的屬性。
  • FromBodyAttribute 現在支援配置允許將這些引數或屬性視為可選的選項:
    C# public IActionResult Post([FromBody(EmptyBodyBehavior = EmptyBodyBehavior.Allow)] MyModel model) { ... }

給予反饋

我們希望您喜歡.NET 5中此版本的ASP.NET Core!我們很想聽聽您有關此最新.NET 5版本的經驗。通過在GitHub上提交問題,讓我們知道您的想法。
感謝您試用ASP.NET Core!


原文:https://devblogs.microsoft.com/aspnet/asp-net-core-updates-in-net-5-preview-7/

相關文章