Nello scorso script (https://www.aspitalia.com/script/1437/Gestire-Tipi-Complessi-Query-String-IParsable-ASP.NET-Core-7.0.aspx), abbiamo visto come, grazie all'interfaccia IParseable, possiamo costruire un oggetto più o meno complesso a partire da una stringa nella request. Quando abbiamo invece diversi parametri, per esempio chiavi in query string, potremmo comunque voler raggrupparli all'interno di un singolo oggetto.
Per esempio, per rappresentare il nome proprio di una persona, potremmo accettare due parametri, "First" e "Last", e utilizzarli per popolare una classe Name:
public class Name { public string? First { get; set; } public string? Last { get; set; } }
Da ASP.NET Core 7, possiamo creare un'action che accetti Name come parametro, e marcarlo con l'attributo AsParameters:
[HttpGet("name")] public IActionResult GetName([FromQuery, AsParameters] Name request) { return this.Ok(request); }
La stessa tecnica funziona con un endpoint su Minimal API:
app.MapGet("/name", ([AsParameters] Name name) => { return "Hello " + name.First + " " + name.Last; });
Un aspetto a cui prestare attenzione è la gestione dei parametri opzionali: come possiamo notare, abbiamo definito entrambe le proprietà di Name come nullable string: in questo modo, ASP.NET Core considererà i due parametri come opzionali, e il nostro endpoint verrà invocato anche se uno dei due - o entrambi - dovessero mancare. Diversamente, sarebbero risultati obbligatori, e in questo caso il binding sarebbe fallito.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Hosting di componenti WebAssembly in un'applicazione Blazor static
Modificare i metadati nell'head dell'HTML di una Blazor Web App
Utilizzare Model as a Service su Microsoft Azure
Utilizzare Tailwind CSS all'interno di React: installazione
Eseguire i worklow di GitHub su runner potenziati
Gestire domini wildcard in Azure Container Apps
Sfruttare gli embedding e la ricerca vettoriale con Azure SQL Database
Supportare lo HierarchyID di Sql Server in Entity Framework 8
Usare una container image come runner di GitHub Actions
Registrare servizi multipli tramite chiavi in ASP.NET Core 8
Gestire liste di tipi semplici con Entity Framework Core
Migliorare la scalabilità delle Azure Function con il Flex Consumption