I QR Code sono oramai incredibilmente diffusi e supportati da tutti i moderni device. Basta avviare la macchina fotografica del nostro smartphone e inquadrare un codice, per avviare automaticamente la action presente nell'immagine, sia essa un link HTML, una chat di WhatsApp o un evento per il calendar.
La libreria in assoluto più diffusa in .NET per generare questi codici è chiamata QRCoder (https://github.com/codebude/QRCoder) e, oltre che su GitHub, è anche disponibile sotto forma di NuGet package:
dotnet add package QRCode
Una volta aggiunta la reference alla nostra solution, possiamo creare una action che generi un QR Code con il codice seguente:
[HttpGet] public IActionResult Get(string url) { var payload = new PayloadGenerator.Url(url).ToString(); var data = new QRCodeGenerator().CreateQrCode(payload, QRCodeGenerator.ECCLevel.Q); var qrCode = new SvgQRCode(data).GetGraphic(20); return this.Content(qrCode, MediaTypeHeaderValue.Parse("image/svg+xml")); }
Nel nostro esempio, creeremo un codice che contenga un link all'URL fornito come parametro. Per farlo, sfruttiamo uno dei vari PayloadGenerator presenti nella libreria (ce ne sono diversi, da connessioni WiFi a BitCoin wallet) per costruire il contenuto desiderato. Il parametro ECCLevel, che dobbiamo passare al QRCodeGenerator, indica il livello di correzione dell'errore di cui vogliamo dotare il nostro codice. Nell'esempio in alto abbiamo scelto il valore Q che indica "Quality".
Come ultimo passaggio, effettuiamo il rendering Svg del codice, creando una istanza di SvgQRCode. Esistono diversi formati di output, da bitmap a PDF, persino ASCII.
Al termine dell'operazione, restituiamo il contenuto con il media type corretto.
Se abbiamo svolto i passaggi correttamente, dovremmo essere in grado di visualizzare un risultato simile a quello in figura.

Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Usare Azure Application Gateway come reverse proxy per ASP.NET Core
Organizzare i moduli sfruttando CommonJS
Parallelizzare le chiamate HTTP con async/await e le Promise in JavaScript
Leggere il valore di un header della richiesta in ASP.NET Core 6
Sopprimere gli errori di concorrenza quando si elimina una entity con Entity Framework 7
Usare Docusaurus per creare un sito di documentazione
Health monitoring con Azure Container App
Tracciare gli eventi tramite i DevTools di Chrome
Leggere la configurazione da Azure KeyVault con logica di retry in ASP.NET Core
Ottenere il riferimento alla finestra che ha aperto un'altra finestra con HTML5 e JavaScript
Abilitare HTTP/3 in ASP.NET Core 7.0
I più letti di oggi
- Sfruttare la local cache del browser tramite gli ETag in #aspnetcore https://aspit.co/cfc di @crad77 #webapi #aspnetmvc #blazor #cache
- Workflow di continuous deployment tramite pull request label in GitHub
- 3 metodi JavaScript che ogni applicazione web dovrebbe contenere
- ASP.NET Website Programming
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!