NOTE: Apart from
(and even then it's questionable, I'm Scottish). These are machine translated in languages I don't read. If they're terrible please contact me.
You can see how this translation was done in this article.
Monday, 12 August 2024
//4 minute read
La cache è una tecnica importante sia per migliorare l'esperienza utente caricando i contenuti più velocemente che per ridurre il carico sul server. In questo articolo vi mostrerò come utilizzare le funzionalità di cache integrate di ASP.NET Core con HTMX per nascondere i contenuti sul lato client.
In ASP.NET Core, ci sono due tipi di Caching offerti
Per impostare questi in ASP.NET Core è necessario aggiungere un paio di servizi nel vostro Program.cs
file
builder.Services.AddResponseCaching();
app.UseResponseCaching();
services.AddOutputCache();
app.UseOutputCache();
Mentre è possibile impostare Response Caching nel vostro Program.cs
è spesso un po 'inflessibile (soprattutto quando si utilizzano le richieste HTMX come ho scoperto). È possibile impostare Response Caching nelle azioni del controller utilizzando il ResponseCache
attributo.
[ResponseCache(Duration = 300, VaryByHeader = "hx-request", VaryByQueryKeys = new[] {"page", "pageSize"}, Location = ResponseCacheLocation.Any)]
Questo cacherà la risposta per 300 secondi e varierà la cache dal hx-request
intestazione e la page
e pageSize
parametri di query. Stiamo anche impostando il Location
a Any
che significa che la risposta può essere memorizzata sul client, sui server proxy intermedi, o entrambi.
Ecco... hx-request
header è l'intestazione che HTMX invia ad ogni richiesta. Questo è importante in quanto consente di nascondere la risposta in modo diverso in base al fatto che si tratti di una richiesta HTMX o di una richiesta normale.
Questa è la nostra corrente. Index
metodo d'azione. Yo ucan vedere che accettiamo una pagina e pageSize parametro qui e abbiamo aggiunto questi come varia per chiavi di query nel ResponseCache
attributo. Significa che le risposte sono "indexate" da queste chiavi e memorizzano contenuti diversi sulla base di queste.
In azione abbiamo anche if(Request.IsHtmx())
Questo è basato sulla Pacchetto HDMX.Net ed essenzialmente controlli per lo stesso hx-request
Intestazione che usiamo per variare la cache. Qui riportiamo una vista parziale se la richiesta è da HTMX.
public async Task<IActionResult> Index(int page = 1,int pageSize = 5)
{
var authenticateResult = GetUserInfo();
var posts =await blogService.GetPosts(page, pageSize);
posts.LinkUrl= Url.Action("Index", "Home");
if (Request.IsHtmx())
{
return PartialView("_BlogSummaryList", posts);
}
var indexPageViewModel = new IndexPageViewModel
{
Posts = posts, Authenticated = authenticateResult.LoggedIn, Name = authenticateResult.Name,
AvatarUrl = authenticateResult.AvatarUrl
};
return View(indexPageViewModel);
}
Output Caching è l'equivalente lato server di Response Caching. Caca l'uscita di un'azione controller. In sostanza il web server memorizza il risultato di una richiesta e la serve per le richieste successive.
[OutputCache(Duration = 3600,VaryByHeaderNames = new[] {"hx-request"},VaryByQueryKeys = new[] {"page", "pageSize"})]
Qui stiamo caching l'uscita dell'azione controller per 3600 secondi e variando la cache dal hx-request
intestazione e la page
e pageSize
parametri di query.
Poiché stiamo memorizzando il lato del server dati per un tempo significativo (i messaggi di aggiornamento solo con un docker push) questo è impostato a più lungo rispetto alla Cache di risposta; potrebbe effettivamente essere infinito nel nostro caso, ma 3600 secondi è un buon compromesso.
Come con la cache di risposta stiamo usando il hx-request
header per variare la cache in base al fatto che la richiesta è da HTMX o no.
ASP.NET Core ha anche integrato il supporto per la cache di file statici. Questo viene fatto impostando il Cache-Control
Intestazione nella risposta. Puoi impostare questo nel tuo Program.cs
Archivio.
Si noti che l'ordine è importante qui, se i file statici hanno bisogno di supporto di autorizzazione si dovrebbe spostare il UseAuthorization
middleware prima del UseStaticFiles
Middleware. Anche il middleware di UseHttpsRedirection dovrebbe essere prima del middleware di UseStaticFiles se ci si affida a questa funzione.
app.UseHttpsRedirection();
var cacheMaxAgeOneWeek = (60 * 60 * 24 * 7).ToString();
app.UseStaticFiles(new StaticFileOptions
{
OnPrepareResponse = ctx =>
{
ctx.Context.Response.Headers.Append(
"Cache-Control", $"public, max-age={cacheMaxAgeOneWeek}");
}
});
app.UseRouting();
app.UseCors("AllowMostlylucid");
app.UseAuthentication();
app.UseAuthorization();
La cache è un potente strumento per migliorare le prestazioni della tua applicazione. Utilizzando le funzionalità di cache integrate di ASP.NET Core è possibile facilmente cache contenuto sul client o server lato. Utilizzando HTMX è possibile nascondere i contenuti sul lato client e fornire viste parziali per migliorare l'esperienza utente.