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
Popolare una classe a partire dal testo, con Semantic Kernel e ASP.NET Core Web API
Testare l'invio dei messaggi con Event Hubs Data Explorer
Generare un hash con SHA-3 in .NET
Gestire la cancellazione di una richiesta in streaming da Blazor
Utilizzare i primary constructor in C#
Utilizzare Model as a Service su Microsoft Azure
Rinnovare il token di una GitHub App durante l'esecuzione di un workflow
C# 12: Cosa c'è di nuovo e interessante
Utilizzare gRPC su App Service di Azure
Gestire liste di tipi semplici con Entity Framework Core
Disabilitare automaticamente un workflow di GitHub (parte 2)
Proteggere le risorse Azure con private link e private endpoints