头图

.NET 7 预览版2 中的 ASP.NET Core 更新

.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;
})

您可以通过设置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!


社区文章
微软 Reactor 上海 是微软为构建开发者社区而提供的一个社区空间,以“予力多元化社区建设,帮助每一个开...

微软 Reactor 是微软为构建开发者社区而提供的一个社区空间,以“予力多元化社区建设,帮助每一个开发者...

109 声望
18 粉丝
0 条评论
推荐阅读
Java on Azure Tooling 6月更新|Azure Toolkit for IntelliJ 与 Gradle插件
大家好,欢迎来到 Java on Azure Tooling 的 6 月更新。在这次更新中,我们将为 Azure toolkit for IntelliJ 引入以应用为中心的新视图,这将使管理界面对用户更加友好。此外,我们还新增了对更多 Azure 服务的支...

MicrosoftReactor阅读 465

封面图
必看!.NET 7 在网络领域的四大更新
最新的 .NET 7 现已发布,我们想介绍一下其在网络领域所做的一些有趣的更改和添加。这篇文章我们将讨论 .NET 7 在 HTTP 空间、新 QUIC API、网络安全和 WebSockets 方面的变化。

微软技术栈1阅读 589

封面图
给 .NET 程序加个「设置开机启动」
前几天写了个「干掉微信只读」的程序,用来解决微信更新 3.9 以后收到文件会自动设置为只读的问题。微信这个设计可以有效地保证收到的原始文件安全性,避免被无意改动。但确实有违某些用户的习惯性操作。「干掉微...

边城1阅读 417

封面图
使用 .NET 7、Blazor 和 .NET MAUI 构建你自己的 Podcast App
.NET Podcast App 首次在 .NET Conf 2021上推出,最近进行了更新以在 .NET Conf 2022 keynote 中突出显示 .NET 7 中的新功能。该 Podcast App 已准备好使用展示 .NET,ASP.NET Core,Blazor,.NET MAUI,Azure Co...

微软技术栈阅读 876

封面图
MASA Stack 1.0 发布会 倒计时一天
​扫描二维码,预约直播2023/1/16 14:00 与你不见不散发布会精彩看点抢先看MASA Stack 1.0 趋势篇世界技术圈在发什么?应用现代化宣布MASA Stack1.0版本正式发布MASA Stack 1.0 产品篇1.0产品架构介绍一站式现代化...

MASA技术团队阅读 621

MASA Stack 1.0 发布会圆满收官
云原生的演进跟大家一起回顾张磊老师在云原生开发者日上关于“云原生技术演进”的分享。介绍整个云原生生态的体现就是一套逻辑链路,就是当有一套概念和方法论之后,就会出现对应的技术和架构,我们在开源社区里就...

MASA技术团队阅读 420

用 Visual Studio 升级 .NET 项目
现在,你已可以使用 Visual Studio 将所有 .NET 应用程序升级到最新版本的 .NET!这一功能可以从 Visual Studio 扩展包中获取,它会升级你的 .NET Framework 或 .NET Core 网页和桌面应用程序。一些项目类型仍正...

微软技术栈阅读 330

封面图

微软 Reactor 是微软为构建开发者社区而提供的一个社区空间,以“予力多元化社区建设,帮助每一个开发者...

109 声望
18 粉丝
宣传栏