Razor è un engine di templating estremamente versatile; lo usiamo ogni giorno per realizzare le view delle applicazioni ASP.NET MVC, ma in realtà può essere sfruttato anche per altri scopi. Per esempio, può essere molto comodo creare dei file cshtml o vbhtml per descrivere template di email o file di report:
@model Customer <html> <body> <p>Ciao, @this.Model.Name</p> <p>ti scriviamo questa mail per dimostrare quanto Razor sia versatile!</p> </body> </html>
Questo tipo di contenuto, a differenza di una normale view, dovrà essere renderizzato all'interno di una variabile string, così che possiamo poi effettivamente utilizzarlo come body del messaggio email. Per questo scopo, possiamo realizzare un extension method simile al seguente, che accetti in ingresso il nome della view e l'istanza del model:
public static string ViewToString<T>(this Controller controller, string viewName, T model) { var controllerContext = new ControllerContext( controller.HttpContext, controller.RouteData, controller); var viewResult = ViewEngines.Engines.FindPartialView(controllerContext, viewName); using (var sw = new StringWriter()) { var viewContext = new ViewContext( controllerContext, viewResult.View, new ViewDataDictionary<T>(), new TempDataDictionary<T>(), sw); viewContext.ViewData.Model = model; try { viewResult.View.Render(viewContext, sw); } finally { viewResult.ViewEngine.ReleaseView(controllerContext, viewResult.View); } return sw.ToString(); } }
Gran parte del metodo consiste nella ricostruzione del contesto di esecuzione, costituito da ControllerContext e ViewContext, necessari a Razor per effettuare il rendering della view. Una volta recuperata la view in base al nome, proprio tramite il ViewContext, possiamo associare il model passato in ingresso.
Una volta che tutte queste variabili sono create, possiamo finalmente invocare il metodo Render e scrivere su uno StringWriter il risultato del rendering.
L'utilizzo di questo metodo è estremamente comodo e semplice:
public ActionResult SendEmail(...) { var customer = new Customer() { Name = "Marco De Sanctis" }; string body = this.ViewToString("emailTemplate", customer); // invio email qui ... }
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Gestione degli stili CSS con le regole @layer
Garantire la provenienza e l'integrità degli artefatti prodotti su GitHub
Utilizzare DeepSeek R1 con Azure AI
Utilizzare il trigger SQL con le Azure Function
Supporto ai tipi DateOnly e TimeOnly in Entity Framework Core
Generare HTML a runtime a partire da un componente Razor in ASP.NET Core
Effettuare il log delle chiamate a function di GPT in ASP.NET Web API
Creare una libreria CSS universale: Immagini
Bloccare l'esecuzione di un pod in mancanza di un'artifact attestation di GitHub
Utilizzare una qualunque lista per i parametri di tipo params in C#
Rendere le variabili read-only in una pipeline di Azure DevOps
Cancellare una run di un workflow di GitHub