Nei precedenti script ci siamo occupati dell'output cache di ASP.NET Core 7: ne abbiamo introdotto i concetti generali (https://www.aspitalia.com/script/1440/Migliorare-Scalabilita-ASP.NET-Core-Output-Cache.aspx), abbiamo visto come controllare i parametri (https://www.aspitalia.com/script/1441/Gestire-Query-String-Neloutput-Cache-ASP.NET-Core.aspx) e come creare policy di cache (https://www.aspitalia.com/script/1442/Definire-Durata-Output-Cache-ASP.NET-Core.aspx).
Tuttavia, tutti i nostri esempi sono stati limitati a Minimal API, che rappresenta il nuovo e compatto modo per esporre endpoint su un progetto ASP.NET Core, ma probabilmente non è diffuso quanto i controller.
Ovviamente, anche i controller supportano la nuova OutputCache, a patto di registrare il middleware nel corretto ordine, ossia prima della chiamata a MapController:
public static void Main(string[] args) { var builder = WebApplication.CreateBuilder(args); // .. altri servizi qui ... builder.Services.AddAuthorization(); builder.Services.AddOutputCache(config => { // .. policy definite qui .. // https://www.aspitalia.com/script/1442/Definire-Durata-Output-Cache-ASP.NET-Core.aspx }); builder.Services.AddControllers(); var app = builder.Build(); // altri middleware... app.UseOutputCache(); app.MapControllers(); app.Run();
A questo punto, non dobbiamo far altro che decorare le nostre action con l'attributo OutputCache:
[HttpGet("demo")] [OutputCache(VaryByQueryKeys = new[] { "name" })] public IActionResult Basic(string name) { return this.Ok($"Hello, {name}, time is {DateTime.Now.ToLongTimeString()}"); } [HttpGet("short")] [OutputCache(PolicyName = "shortCache")] public IActionResult Short(string name) { return this.Ok($"Hello, {name}, time is {DateTime.Now.ToLongTimeString()}"); } [HttpGet("long")] [OutputCache(PolicyName = "longCache")] public IActionResult Long(string name) { return this.Ok($"Hello, {name}, time is {DateTime.Now.ToLongTimeString()}"); } [HttpGet("inline")] [OutputCache(Duration = 10)] public IActionResult Inline(string name) { return this.Ok($"Hello, {name}, time is {DateTime.Now.ToLongTimeString()}"); }
Come possiamo vedere dal codice in alto, le varie impostazioni che nel caso di minimal API vengono assegnate tramite lambda expression, in questo caso corrispondono ad altrettanti parametri dell'attributo OutputCache.
Le policy sono ovviamente condivise tra minimal API e controller - e pertanto è una best practice utilizzarle per definire la durata di cache, così come gli ulteriori parametri che vedremo nel corso dei prossimi script.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Controllare gli accessi IP alle app con Azure Container Apps
Usare gateway dedicati con Azure Cosmos DB per migliorare le prestazioni
Usare domini personalizzati con Azure Container App
Migliorare la scalabilità di ASP.NET Core 7 grazie all'output cache
Autenticazione basata su certificati con ASP.NET Core
GitHub <3 .NET
Specificare il versioning nel path degli URL in ASP.NET Web API
Intercettare gli eventi di creazione degli oggetti con Entity Framework 7
Utilizzare parametri a livello di controller nel routing di ASP.NET Core
Migrare un progetto ASP.NET Core da .NET 6 a .NET 7
Usare ASP.NET Core dev tunnels per testare le applicazioni su internet
Usare Azure Application Gateway come reverse proxy per ASP.NET Core