In caso di esigenze particolari, in cui vogliamo configurare l'output cache di ASP.NET Core in base a nostre logiche personalizzate, una buona soluzione è quella di incapsulare tutte queste logiche all'interno di una classe, creando una Custom Policy.
Si tratta di una classe che implementa l'interfaccia IOutputCachePolicy:
public interface IOutputCachePolicy { // invocato prima che il middleware di cache sia eseguito // qui possiamo configurare la maggior parte delle opzioni e abilitarlo/disabilitarlo // in base alle nostre esigenze ValueTask CacheRequestAsync(OutputCacheContext context, CancellationToken cancellation); // invocato quando la risposta è stata trovata in cache, appena prima di restituirla ValueTask ServeFromCacheAsync(OutputCacheContext context, CancellationToken cancellation); // invocato prima di eseguire la risposta dal server, e quindi // prima che venga memorizzata in cache ValueTask ServeResponseAsync(OutputCacheContext context, CancellationToken cancellation); }
Per esempio, immaginiamo di voler implementare un sistema di telemetria con Application Insights, così da tracciare quando le richieste vengono servite tramite OutputCache.
Per farlo, possiamo creare la nostra ApplicationInsightsPolicy:
public class ApplicationInsightsPolicy : IOutputCachePolicy { private TelemetryClient _client; public ApplicationInsightsPolicy(TelemetryClient client) { _client = client; } public ValueTask CacheRequestAsync(OutputCacheContext context, CancellationToken cancellation) { return ValueTask.CompletedTask; } public ValueTask ServeFromCacheAsync(OutputCacheContext context, CancellationToken cancellation) { _client.TrackEvent(new EventTelemetry("CacheHit") { Properties = { { "Url", context.HttpContext.Request.GetDisplayUrl() }, { "CacheTags", string.Join(",", context.Tags) } } }); return ValueTask.CompletedTask; } public ValueTask ServeResponseAsync(OutputCacheContext context, CancellationToken cancellation) { return ValueTask.CompletedTask; } }
L'implementazione è davvero banale: quando la risposta viene servita dalla cache, l'OutputCacheMiddleware invocherà il metodo ServeFromCacheAsync, all'interno del quale abbiamo inserito la nostra logica di tracking tramite TelemetryClient.
Abbiamo poi lasciato vuoti gli altri metodi, per i quali non dobbiamo specificare alcuna logica.
A questo punto non ci resta che registrare la nostra custom policy nella BasePolicy, così che venga automaticamente associata a tutti gli endpoint per i quali l'output cache sia attivo:
builder.Services.AddOutputCache(config => { config.AddBasePolicy(policy => { policy.Expire(TimeSpan.FromMinutes(60)); policy.AddPolicy<ApplicationInsightsPolicy>(); }); });
Se abbiamo configurato correttamente Application Insights, vedremo questo nostro evento apparire nei log, così che possiamo utilizzarlo per generare statistiche, dashboard e quant'altro.

Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Creare agenti facilmente con Azure AI Agent Service
Ricevere notifiche sui test con Azure Load Testing
Montare Azure Blob Storage su Linux con BlobFuse2
Applicare un filtro per recuperare alcune issue di GitHub
Potenziare la ricerca su Cosmos DB con Full Text Search
Change tracking e composition in Entity Framework
Persistere la ChatHistory di Semantic Kernel in ASP.NET Core Web API per GPT
Testare l'invio dei messaggi con Event Hubs Data Explorer
Abilitare automaticamente il force push di un gruppo su Azure DevOps
Eseguire una ricerca avanzata per recuperare le issue di GitHub
Scrivere selettori CSS più semplici ed efficienti con :is()
Gestire codice JavaScript con code splitting e lazy loading
I più letti di oggi
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Documentare i servizi REST con Swagger e OpenAPI con .NET 9
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!