Quando realizziamo una action in ASP.NET MVC, abbiamo a disposizione diversi tipi di oggetti, che derivano dalla classe ActionResult, che possiamo sfruttare per restituire al nostro chiamante varie tipologie di contenuti. Ad esempio, la classe FileContentResult può essere sfruttata per inviare dei dati binari. Se abbiamo salvato un'immagine all'interno di un campo di database, possiamo realizzare una action che la renderizzi tramite il codice seguente:
public FileContentResult GetImage(int Id) { // recupero l'immagine dal database using (var context = new SampleEntities()) { Image image = context.Images.Find(Id); if (image != null) { return new FileContentResult(image.Immagine, image.TipoImmagine); } else { return null; } } }
Il metodo in alto non fa altro che recuperare l'immagine memorizzata nel database tramite il suo identificativo e, nel caso non sia null, restituisce un FileContentResult. Il costruttore di quest'ultimo accetta una parametro di tipo byte e uno di tipo string, che verranno utilizzati rispettivamente per impostare il vero e proprio contenuto della response e il suo mime type.
Per sfruttare questa action all'interno di una view, basta invocarla come src di un tag img:
<img alt="" width="200" height="200" src="@Url.Action("GetImage", "Home", new { item.ID })" />
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Applicare un filtro per recuperare alcune issue di GitHub
Gestione file Javascript in Blazor con .NET 9
Creare una libreria CSS universale: Immagini
.NET Aspire per applicazioni distribuite
Ottenere un token di accesso per una GitHub App
Utilizzare il metodo CountBy di LINQ per semplificare raggruppamenti e i conteggi
Gestire eccezioni nei plugin di Semantic Kernel in ASP.NET Core Web API
Il nuovo controllo Range di Blazor 9
Esporre i propri servizi applicativi con Semantic Kernel e ASP.NET Web API
Utilizzare Azure Cosmos DB con i vettori
.NET Conference Italia 2024
Usare il colore CSS per migliorare lo stile della pagina