关于.net:更新丨NET-7-预览版2-中的-ASPNET-Core

78次阅读

共计 4066 个字符,预计需要花费 11 分钟才能阅读完成。

.NET 7 预览版 2 现已推出,其中包含对 ASP.NET Core 的许多重大改良。
以下是此预览版中新增内容的摘要:

  • 推断来自服务的 API 控制器操作参数;
  • SignalR 集线器办法的依赖注入;
  • 为 minimal API 提供端点形容和摘要;
  • 在最小的 API 中绑定来自标头和查问字符串的数组和 StringValue;
  • 自定义 cookie 批准值。

无关为 .NET 7 打算的 ASP.NET Core 工作的更多详细信息,请参阅 GitHub 上的 .NET 7 的残缺 ASP.NET Core 路线图。

开始应用

要开始应用 .NET 7 Preview 2 中的 ASP.NET Core,请装置 .NET 7 SDK。

如果您在 Windows 上应用 Visual Studio,咱们倡议装置最新的 Visual Studio 2022 预览版。Visual Studio for Mac 对 .NET 7 预览的反对尚不可用,但行将推出。
要装置最新的 .NET WebAssembly 构建工具,请从晋升的命令提示符处运行以下命令:dotnet workload install wasm-tools。

降级现有我的项目

要将现有的 ASP.NET Core 利用从 .NET 7 Preview 1 降级到 .NET 7 Preview 2:

  • 将所有 Microsoft.AspNetCore. 包援用更新到 7.0.0-preview.2.
  • 将所有 Microsoft.Extensions. 包援用更新到 7.0.0-preview.2.

另请参阅 .NET 7 的 ASP.NET Core 中的重大更改的残缺列表。

推断来自服务的 API 控制器操作参数

当类型配置为服务时,API 控制器操作的参数绑定当初通过依赖注入绑定参数。这意味着不再须要将 [FromServices] 属性显式利用于参数。

Services.AddScoped<SomeCustomType>();

[Route("[controller]")]
[ApiController]
public class MyController : ControllerBase
{
    // Both actions will bound the SomeCustomType from the DI container
    public ActionResult GetWithAttribute([FromServices]SomeCustomType service) => Ok();
    public ActionResult Get(SomeCustomType service) => Ok();}

您能够通过设置 DisableImplicitFromServicesParameters 来禁用该性能:

Services.Configure<ApiBehaviorOptions>(options =>
{options.DisableImplicitFromServicesParameters = true;})

SignalR 集线器办法的依赖注入

SignalR 集线器办法当初反对通过依赖注入 (DI) 注入服务。

Services.AddScoped<SomeCustomType>();

public class MyHub : Hub
{
    // SomeCustomType comes from DI by default now
    public Task Method(string text, SomeCustomType type) => Task.CompletedTask;
}

您能够通过设置 DisableImplicitFromServicesParameters 来禁用该性能:

services.AddSignalR(options =>
{options.DisableImplicitFromServicesParameters = true;});

要显式标记要从配置的服务绑定的参数,请应用 [FromServices] 属性:

public class MyHub : Hub
{public Task Method(string arguments, [FromServices] SomeCustomType type);
}

为 Minimal API 提供端点形容和摘要

Minimal API 当初反对应用用于 OpenAPI 标准生成的形容和摘要来正文操作。您能够应用扩大办法在 Minimal API 应用程序中为路由处理程序设置这些形容和摘要:

app.MapGet("/hello", () => ...)
  .WithDescription("Sends a request to the backend HelloService to process a greeting request.");

或者通过路由处理程序委托上的属性设置形容或摘要:

app.MapGet("/hello", [EndpointSummary("Sends a Hello request to the backend")]() => ...)

在 Minimal API 中绑定来自标头和查问字符串的数组和 StringValue

在此版本中,您当初能够将 HTTPS 标头和查问字符串中的值绑定到原始类型数组、字符串数组或 StringValues:

// Bind query string values to a primitive type array
// GET  /tags?q=1&q=2&q=3
app.MapGet("/tags", (int[] q) => $"tag1: {q[0]} , tag2: {q[1]}, tag3: {q[2]}")

// Bind to a string array
// GET /tags?names=john&names=jack&names=jane
app.MapGet("/tags", (string[] names) => $"tag1: {names[0]} , tag2: {names[1]}, tag3: {names[2]}")

// Bind to StringValues
// GET /tags?names=john&names=jack&names=jane
app.MapGet("/tags", (StringValues names) => $"tag1: {names[0]} , tag2: {names[1]}, tag3: {names[2]}")

您还能够将查问字符串或标头值绑定到简单类型的数组,只有该类型具备 TryParse 实现,如下例所示。

// Bind query string values to a primitive type array
// GET  /tags?q=1&q=2&q=3
app.MapGet("/tags", (int[] q) => $"tag1: {q[0]} , tag2: {q[1]}, tag3: {q[2]}")

// Bind to a string array
// GET /tags?names=john&names=jack&names=jane
app.MapGet("/tags", (string[] names) => $"tag1: {names[0]} , tag2: {names[1]}, tag3: {names[2]}")

// Bind to StringValues
// GET /tags?names=john&names=jack&names=jane
app.MapGet("/tags", (StringValues names) => $"tag1: {names[0]} , tag2: {names[1]}, tag3: {names[2]}")

自定义 cookie 批准值

您当初能够应用新的 CookiePolicyOptions.ConsentCookieValue 属性指定用于跟踪用户是否批准 cookie 应用策略的值。

感激 @daviddesmet 奉献了这项改良!

申请无关 IIS 卷影复制的反馈

在 .NET 6 中,咱们为 IIS 的 ASP.NET Core 模块 (ANCM) 增加了对影子复制应用程序程序集的实验性反对。当 ASP.NET Core 应用程序在 Windows 上运行时,二进制文件被锁定,因而无奈批改或替换它们。您能够通过部署应用程序离线文件来进行应用程序,但有时这样做不不便或不可能。卷影复制容许在利用程序运行时通过复制程序集来更新应用程序程序集。

您能够通过在 web.config 中自定义 ANCM 处理程序设置来启用卷影复制:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <system.webServer>
    <handlers>
      <remove name="aspNetCore"/>
      <add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModuleV2" resourceType="Unspecified"/>
    </handlers>
    <aspNetCore processPath="%LAUNCHER_PATH%" arguments="%LAUNCHER_ARGS%" stdoutLogEnabled="false" stdoutLogFile=".logsstdout">
      <handlerSettings>
        <handlerSetting name="experimentalEnableShadowCopy" value="true" />
        <handlerSetting name="shadowCopyDirectory" value="../ShadowCopyDirectory/" />
      </handlerSettings>
    </aspNetCore>
  </system.webServer>
</configuration>

咱们正在钻研使 IIS 中的卷影复制成为 .NET 7 中 ASP.NET Core 的一项性能,并且咱们正在寻求无关该性能是否满足用户要求的更多反馈。如果您将 ASP.NET Core 部署到 IIS,请尝试应用卷影复制并在 GitHub 上与咱们分享您的反馈。

总结

咱们心愿您喜爱 .NET 7 中的 ASP.NET Core 预览版。通过在 GitHub 上提交问题,让咱们晓得您对这些新改良的认识。

感谢您试用 ASP.NET Core!

正文完
 0