Creare un'API con Funzioni di Azure

Completato

A questo punto, è necessario creare un'API per l'app per la lista della spesa.

Funzioni di Azure

Uno dei principali vantaggi di App Web statiche di Azure è quello di ospitare l'app Web insieme a un'API creata con Funzioni di Azure. App Web statiche di Azure distribuisce a livello globale gli asset statici dell'app Web e ospita l'API in Funzioni di Azure. Con questa configurazione, si ottengono la disponibilità e la velocità garantite dalla distribuzione globale degli asset dell'app Web. È anche importante cosa non si ottiene.

Non sono necessarie la configurazione e la manutenzione di un server completo per il front-end o il back-end. Ecco il vantaggio di App Web statiche di Azure: la semplicità di pubblicazione dell’app e dell'API con attività minime di configurazione e manutenzione.

Funzioni di Azure rende disponibili gli endpoint delle route, non richiede la configurazione o la manutenzione di un server back-end completo e fornisce scalabilità orizzontale e ridimensionamento automatici su richiesta. Tutto questo fa di Funzioni di Azure un ottimo partner di API per l'app Web per la lista della spesa, che rende disponibili gli asset statici.

App Web statiche di Azure genera un URL univoco per il sito, che è disponibile nella scheda Panoramica nel portale. L'API è disponibile a questo stesso URL aggiungendo /api all'URL.

API per la lista della spesa

L'app per la lista della spesa permette agli utenti di ottenere, aggiungere, aggiornare ed eliminare articoli nella propria lista. È quindi logico che l'API includa endpoint in grado di soddisfare tali esigenze.

Ecco i quattro endpoint:

Metodi Endpoint delle route Endpoint API completo
GET products api/products
POST products api/products
PUT products/:id api/products/:id
DELETE products/:id api/products/:id

Si noti che le richieste HTTP GET vengono instradate in api/products. Il prefisso api è riservato agli endpoint API nell'app. È possibile definire qualsiasi altra route in base alle esigenze del sito, ma api punterà sempre all'app Funzioni di Azure.

Creare un'API per l'app Web

Fino a ora è stato usato un framework front-end. In breve tempo è possibile aggiungere un'API e connetterla all'app front-end. Il repository include un progetto Api che contiene un progetto di Funzioni di Azure incompleto ed endpoint HTTP per richieste PUT, POST e DELETE per i prodotti. L'API è priva della funzione HTTP GET. Dopo aver completato l'API del progetto Funzioni di Azure e aver aggiunto la funzione mancante, è possibile connettere l'API all'app Web front-end.

Visualizzare in anteprima le modifiche apportate all'app Web

Prima di apportare modifiche a un'app, è consigliabile creare un nuovo ramo per le modifiche. Dato che si apportano diverse modifiche durante il completamento dell'API per l'app, è consigliabile creare un ramo per tali modifiche.

Dopo aver apportato le modifiche, è meglio osservare come funzionano prima di decidere di applicarle. Dopo aver creato una richiesta pull dal nuovo ramo al ramo principale, GitHub Actions compila l'app e l'API e distribuisce entrambe in un URL di anteprima. Con questo URL di anteprima è possibile lasciare l'app Web in esecuzione con App Web statiche di Azure, ma anche visualizzare un secondo URL con i risultati della richiesta pull.

Configurare la comunicazione tra l'app Web e l'API

Quando si esegue l'API in locale, per impostazione predefinita viene usata la porta 7071. L'app Web usa una porta locale diversa. Quando l'app Web tenta di effettuare una richiesta HTTP dalla propria porta alla porta 7071 dell'API, sta effettuando l’operazione nota come condivisione di risorse di origini diverse (CORS). Il browser impedisce il completamento della richiesta HTTP, a meno che il server API non consenta alla richiesta di procedere.

La condivisione di risorse tra le origini (CORS) non è un aspetto di cui preoccuparsi quando si esegue la pubblicazione in App Web statiche di Azure. App Web statiche di Azure configura automaticamente l'app in modo che possa comunicare con l'API su Azure usando un proxy inverso. Un proxy inverso permette all'app Web e all'API di apparire come appartenenti allo stesso dominio Web. Di conseguenza, è necessario configurare la condivisione di risorse tra le origini solo in caso di esecuzione in locale.

Passaggi successivi

È ora possibile creare l'API e configurare gli endpoint HTTP per l'app per la lista della spesa.