Sempre più spesso i server web che ci forniscono le API, richiedono l'accesso ai loro servizi con il protocollo oAuth 2.0.
Questa versione differisce dalla precedente per il fatto che sono richiesti altri parametri oltre alla chiave principale ed inoltre, questi dati non tutti vengono passati in query string, ma vengono utilizzati per costruire la signature che permetterà al client di essere riconosciuto dal server.
Windows Phone non fornisce un modo "standard" che possa andare bene per tutti i servizi: possiamo crearne una libreria allo scopo, che permette, in pochi semplici passi, di ottenere un URL per effettuare la richiesta.
const string consumerKey = "your-consumer-key"; const string consumerSecret = "your-consumer-secret"; const string token = "your-token-key"; const string tokenSecret = "your-token-secret"; Uri url = new Uri("http://api.yelp.com/v2/search?term=food&location=Milano", UriKind.Absolute); OAuthBase oauth = new OAuthBase(url, consumerKey, consumerSecret, token, tokenSecret, OAuthBase.HttpMethodTypes.GET, OAuthBase.SignatureTypes.HMACSHA1); string completeUrl = oauth.GetUrl();
Nel codice precedente la richiesta viene inoltrata ad un servizio offerto da Yelp, per ricercare un qualsiasi locale che vende del cibo nella zona di Milano.
Preparate le variabili contenenti l'URL a cui fare la chiamata e le chiavi private che vi fornisce il servizio stesso, basta fare una chiamata al costruttore della classe OAuthBase ed una chiamata alla funzione GetUrl, che ci restituisce l'URL corretto per fare la richiesta al server.
Rispetto ad altre librerie, quella usata nell'esempio e allegata allo script è molto semplice ed immediata da utilizzare.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Implementare il throttle in JavaScript
Creare una libreria CSS universale - Rotazione degli elementi
Utilizzare Containers in .NET Aspire
Utilizzare Hybrid Cache in .NET 9
Supportare la crittografia di ASP.NET Core con Azure Container App
Configurare automaticamente un webhook in Azure DevOps
Usare i servizi di Azure OpenAI e ChatGPT in ASP.NET Core con Semantic Kernel
Testare il failover sulle region in Azure Storage
Utilizzare WebJobs su Linux con Azure App Service
Usare i settings di serializzazione/deserializzazione di System.Text.Json di ASP.NET all'interno di un'applicazione non web
Gestione dei nomi con le regole @layer in CSS
Introduzione alle Container Queries
I più letti di oggi
- Utilizzare WebJobs su Linux con Azure App Service
- Le novità di C#6 e Visual Studio 2015
- domani su @aspitalia troverete un articolo speciale dedicato a Windows Phone 8: non ... https://aspit.co/wp-summit #WPSummit
- chiudiamo con @GentiliMoreno: autenticazione e autorizzazione per #asp.netmvc e #webapi con #owin: https://aspit.co/web14-live #aspilive