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
Gestire la cancellazione di una richiesta in streaming da Blazor
Creare una libreria CSS universale: Cards
Supporto ai tipi DateOnly e TimeOnly in Entity Framework Core
Applicare un filtro per recuperare alcune issue di GitHub
Generare HTML a runtime a partire da un componente Razor in ASP.NET Core
Utilizzare la funzione EF.Parameter per forzare la parametrizzazione di una costante con Entity Framework
Evitare (o ridurre) il repo-jacking sulle GitHub Actions
Generare una User Delegation SAS in .NET per Azure Blob Storage
Supportare lo HierarchyID di Sql Server in Entity Framework 8
Utilizzare un numero per gestire la concorrenza ottimistica con SQL Server ed Entity Framework
Paginare i risultati con QuickGrid in Blazor
Referenziare un @layer più alto in CSS