Migrar do ASP.NET Core no .NET 8 para o ASP.NET Core no .NET 9
Este artigo explica como atualizar um ASP.NET Core no .NET 8 para o ASP.NET Core no .NET 9.
Pré-requisitos
Visual Studio 2022 com a carga de trabalho de desenvolvimento Web e do ASP.NET.
Atualizar a versão do SDK do .NET Core em global.json
Se você depende de um arquivo global.json
para o direcionamento a uma versão específica do SDK do .NET Core, atualize a propriedade version
para a versão do SDK do .NET 9.0 instalada. Por exemplo:
{
"sdk": {
- "version": "8.0.100"
+ "version": "9.0.100"
}
}
Atualizar a estrutura de destino
Atualize o TFM (Moniker da Estrutura de Destino) do arquivo de projeto para net9.0
:
<Project Sdk="Microsoft.NET.Sdk.Web">
<PropertyGroup>
- <TargetFramework>net8.0</TargetFramework>
+ <TargetFramework>net9.0</TargetFramework>
</PropertyGroup>
</Project>
Referências do pacote de atualização
No arquivo do projeto, atualize o atributo Microsoft.AspNetCore.*
de cada referência de pacote Microsoft.EntityFrameworkCore.*
, Microsoft.Extensions.*
, System.Net.Http.Json
e Version
para 9.0.0 ou posterior. Por exemplo:
<ItemGroup>
- <PackageReference Include="Microsoft.AspNetCore.JsonPatch" Version="8.0.2" />
- <PackageReference Include="Microsoft.EntityFrameworkCore.Tools" Version="8.0.2" />
- <PackageReference Include="Microsoft.Extensions.Caching.Abstractions" Version="8.0.0" />
- <PackageReference Include="System.Net.Http.Json" Version="8.0.0" />
+ <PackageReference Include="Microsoft.AspNetCore.JsonPatch" Version="9.0.0" />
+ <PackageReference Include="Microsoft.EntityFrameworkCore.Tools" Version="9.0.0" />
+ <PackageReference Include="Microsoft.Extensions.Caching.Abstractions" Version="9.0.0" />
+ <PackageReference Include="System.Net.Http.Json" Version="9.0.0" />
</ItemGroup>
Substitua UseStaticFiles
por MapStaticAssets
Otimize o tratamento de arquivos estáticos em seus aplicativos Web substituindo UseStaticFiles por MapStaticAssets no arquivo do Program
aplicativo:
- app.UseStaticFiles();
+ app.MapStaticAssets();
Nos aplicativos MVC e Razor Pages, você também precisa encadear uma chamada para .WithStaticAssets
depois MapRazorPages
ou MapControllerRoute
em Program.cs
. Para obter um exemplo, consulte os arquivos estáticos no ASP.NET Core.
ASP.NET Core automaticamente imprime e pré-compacta seus arquivos estáticos no momento da compilação e publicação e, em seguida MapStaticAssets , exibe os arquivos otimizados como pontos de extremidade usando o roteamento de ponto de extremidade com cabeçalhos de cache apropriados.
Para resolver os nomes de arquivo com impressão digital do seu aplicativo:
Em Blazor aplicativos, use a ComponentBase.Assets propriedade. Atualize as referências explícitas a ativos estáticos em Razor arquivos de componente (
.razor
) para usar@Assets["{ASSET PATH}"]
, em que o espaço reservado{ASSET PATH}
é o caminho para o ativo. Observe que isso NÃO deve ser feito para os scripts de Blazor estrutura (blazor.*.js
). No exemplo a seguir, o Bootstrap, a folha de estilo do Blazor aplicativo de modelo de projeto (app.css
) e a folha de estilo de isolamento CSS (com base no namespace de um aplicativo deBlazorSample
) estão vinculados em um componente raiz, normalmente oApp
componente (Components/App.razor
):<link rel="stylesheet" href="@Assets["bootstrap/bootstrap.min.css"]" /> <link rel="stylesheet" href="@Assets["app.css"]" /> <link rel="stylesheet" href="@Assets["BlazorSample.styles.css"]" />
Nos aplicativos MVC e Razor Pages, os auxiliares de script e tag de link resolverão automaticamente os nomes de arquivo com impressão digital.
Para resolver os nomes de arquivo com impressão digital ao importar módulos JavaScript, adicione um mapa de importação gerado:
Em Blazor aplicativos, adicione o componente (ImportMap) ao
<head>
conteúdo do componente raiz do aplicativo, normalmente noApp
componente (App.razor
):<ImportMap />
Em aplicativos MVC e Razor páginas, adicione
<script type="importmap"></script>
ao cabeçalho do arquivo de layout principal, que é atualizado pelo Auxiliar de Marca de Mapa de Importação.
Para saber mais, consulte os recursos a seguir:
Blazor
Adote a serialização de estado de autenticação simplificada para Blazor Web Apps
Blazor Web AppOpcionalmente, o s pode adotar a serialização simplificada do estado de autenticação.
No projeto do servidor:
Remova o provedor de estado de autenticação persistente (
PersistingAuthenticationStateProvider.cs
).Remova o registro de serviço do
Program
arquivo. Em vez disso, encadeie uma chamada para AddAuthenticationStateSerialization on AddRazorComponents:- builder.Services.AddScoped<AuthenticationStateProvider, PersistingAuthenticationStateProvider>(); builder.Services.AddRazorComponents() .AddInteractiveServerComponents() .AddInteractiveWebAssemblyComponents() + .AddAuthenticationStateSerialization();
A API só serializa as declarações de nome e função do lado do servidor para acesso no navegador. Para incluir todas as declarações, defina SerializeAllClaims como true
:
.AddAuthenticationStateSerialization(options => options.SerializeAllClaims = true);
No projeto do cliente (.Client
):
Remova o provedor de estado de autenticação persistente (
PersistentAuthenticationStateProvider.cs
).Remova o registro de serviço do
Program
arquivo. Em vez disso, chame AddAuthenticationStateDeserialization a coleção de serviços:- builder.Services.AddSingleton<AuthenticationStateProvider, PersistentAuthenticationStateProvider>(); + builder.Services.AddAuthenticationStateDeserialization();
Para obter mais informações, confira Novidades do ASP.NET Core 9.0.
O atributo de renderização de streaming não requer mais o parâmetro true
No .NET 8, a renderização de streaming requer que você passe true
para o parâmetro enabled
:
@attribute [StreamRendering(true)]
No .NET 9 ou posterior, true
pode ser removido opcionalmente, pois true
agora é o padrão para o parâmetro enabled
:
@attribute [StreamRendering]