Path addizionali per gli asset in ASP.NET Core MVC

di Marco De Sanctis, in ASP.NET Core,

Nello scorso script abbiamo parlato del nuovo MapStaticAssets, introdotto in ASP.NET Core 9, che presenta alcune ottimizzazioni per servire file statici in maniera ancora più efficiente che in passato.

Questo metodo lavora bene con i file già presenti a compile time, visto che questi vengono compressi durante la build e catturati su un manifest autogenerato, così da essere pronti per essere poi trasferiti ai vari client.

Quando però i file sono dinamici - per esempio foto caricate da utenti - questo sistema è meno efficiente. La buona notizia, però, è che può essere combinato con il "vecchio" UseStaticFiles. Supponiamo per esempio che nella nostra applicazione consentiamo l'upload di immagini all'interno di una directory Images:

public class Program
{
    public static void Main(string[] args)
    {
        // .. altro codice qui ..

        app.MapStaticAssets();
        app.UseStaticFiles(new StaticFileOptions() 
        {
            FileProvider = new PhysicalFileProvider(
                Path.Combine(builder.Environment.ContentRootPath, "Images")),
            RequestPath = "/UserImages"
        });

        ...

        app.Run();
    }
}

Nell'esempio in alto abbiamo usato MapStaticAssets per configurare tutti i file contenuti all'interno di wwwroot, mentre abbiamo configurato UseStaticFiles per la cartella Images. In particolare, abbiamo sfruttato un PhysicalFileProvider per mappare il contenuto di questa directory sul path virtuale /UserImages:

<div class="text-center">
    <img src="~/UserImages/dotnet.jpg" width="400px" />
</div>

Commenti

Visualizza/aggiungi commenti

| Condividi su: Twitter, Facebook, LinkedIn

Per inserire un commento, devi avere un account.

Fai il login e torna a questa pagina, oppure registrati alla nostra community.

Approfondimenti

I più letti di oggi