Aggiungere un'API ad App Web statiche di Azure con Funzioni di Azure
È possibile aggiungere API serverless per App Web statiche di Azure basate su Funzioni di Azure. Questo articolo illustra come aggiungere e distribuire un'API in un sito App Web statiche di Azure.
Nota
Le funzioni fornite per impostazione predefinita in App Web statiche sono preconfigurate per fornire endpoint API sicuri e supportano solo funzioni attivate da HTTP. Per informazioni su come differiscono dalle app autonome Funzioni di Azure, vedere Supporto api con Funzioni di Azure.
Prerequisiti
- Account Azure con una sottoscrizione attiva.
- Se non si dispone di un account è possibile crearne uno gratuitamente.
- Visual Studio Code.
- App Web statiche di Azure'estensione per Visual Studio Code.
- Estensione Funzioni di Azure per Visual Studio Code.
- Node.js v18 per eseguire l'app front-end e l'API.
Suggerimento
È possibile usare lo strumento nvm per gestire più versioni di Node.js nel sistema di sviluppo. In Windows è possibile installare NVM per Windows tramite Winget.
Creare l'app Web statica
Prima di aggiungere un'API, creare e distribuire un'applicazione front-end in App Web statiche di Azure seguendo la guida introduttiva Creazione del primo sito statico con App Web statiche di Azure.
Dopo aver distribuito un'applicazione front-end in App Web statiche di Azure, clonare il repository dell'app. Ad esempio, è possibile clonare il repository usando la git
riga di comando.
Prima di eseguire il comando seguente, assicurarsi di sostituire <YOUR_GITHUB_USERNAME>
con il nome utente di GitHub.
git clone https://github.com/<YOUR_GITHUB_USERNAME>/my-first-static-web-app
In Visual Studio Code aprire la radice del repository dell'app. La struttura di cartelle contiene l'origine per l'app front-end e il flusso di lavoro gitHub App Web statiche nella cartella .github/workflows.
├── .github
│ └── workflows
│ └── azure-static-web-apps-<DEFAULT_HOSTNAME>.yml
│
└── (folders and files from your static web app)
Creare l'API
Si crea un progetto Funzioni di Azure per l'API dell'app Web statica. Per impostazione predefinita, l'estensione App Web statiche Visual Studio Code crea il progetto in una cartella denominata api nella radice del repository.
Premere F1 per aprire il riquadro comandi.
Selezionare App Web statiche di Azure: Crea funzione HTTP.... Se viene richiesto di installare l'estensione Funzioni di Azure, installarla ed eseguire di nuovo questo comando.
Quando richiesto, immettere i valori seguenti:
Richiesta Valore Selezionare una lingua JavaScript Selezionare un modello di programmazione V4 Specificare un nome di funzione message Suggerimento
Per altre informazioni sulle differenze tra i modelli di programmazione, vedere la guida per sviluppatori di Funzioni di Azure
Viene generato un progetto Funzioni di Azure con una funzione attivata da HTTP. L'app ha ora una struttura di progetto simile all'esempio seguente.
├── .github │ └── workflows │ └── azure-static-web-apps-<DEFAULT_HOSTNAME>.yml │ ├── api ├── └──src │ │ │ functions │ │ │ └── message.js │ │ └── index.js │ ├── .funcignore │ ├── host.json │ ├── local.settings.json │ ├── package-lock.json │ └── package.json │ └── (...plus other folders and files from your static web app)
Modificare quindi la
message
funzione per restituire un messaggio al front-end. Aggiornare la funzione in src/functions/message.js con il codice seguente.const { app } = require('@azure/functions'); app.http('message', { methods: ['GET', 'POST'], authLevel: 'anonymous', handler: async (request, context) => { return { body: `Hello, from the API!` }; } });
Suggerimento
È possibile aggiungere altre funzioni API eseguendo di nuovo il comando App Web statiche di Azure: Crea funzione HTTP.
Aggiornare l'app front-end per chiamare l'API
Aggiornare l'app front-end per chiamare l'API in /api/message
e visualizzare il messaggio di risposta.
Se sono state usate le guide introduttive per creare l'app, usare le istruzioni seguenti per applicare gli aggiornamenti.
Aggiornare il contenuto del file di src/index.html con il codice seguente per recuperare il testo dalla funzione API e visualizzarlo sullo schermo.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="stylesheet" href="styles.css">
<title>Vanilla JavaScript App</title>
</head>
<body>
<main>
<h1>Vanilla JavaScript App</h1>
<p>Loading content from the API: <b id="name">...</b></p>
</main>
<script>
(async function() {
const { text } = await( await fetch(`/api/message`)).json();
document.querySelector('#name').textContent = text;
}());
</script>
</body>
</html>
Eseguire il front-end e l'API in locale
Per eseguire l'app front-end e l'API in locale, App Web statiche di Azure fornisce un'interfaccia della riga di comando che emula l'ambiente cloud. L'interfaccia della riga di comando usa Funzioni di Azure Core Tools per eseguire l'API.
Installa gli strumenti da riga di comando
Assicurarsi di avere installato gli strumenti da riga di comando necessari.
Importante
Per migliorare la sicurezza delle distribuzioni dall'interfaccia della riga di comando di App Web statiche, è stata introdotta una modifica di rilievo che richiede l'aggiornamento alla versione più recente (2.0.2) dell'interfaccia della riga di comando di App Web statiche entro il 15 gennaio 2025.
npm install -g @azure/static-web-apps-cli
Suggerimento
Se non si vuole installare la swa
riga di swa
comando a livello globale, è possibile usare npx swa
anziché nelle istruzioni seguenti.
Creare un'app front-end
Se l'app usa un framework, compilare l'app per generare l'output prima di eseguire l'interfaccia della riga di comando di App Web statiche.
Non è necessario compilare l'app.
Eseguire l'applicazione in locale
Eseguire l'app front-end e l'API insieme avviando l'app con l'interfaccia della riga di comando di App Web statiche. L'esecuzione delle due parti dell'applicazione in questo modo consente all'interfaccia della riga di comando di gestire l'output di compilazione del front-end da una cartella e rende l'API accessibile all'app in esecuzione.
Nella radice del repository avviare l'interfaccia della riga di comando App Web statiche con il
start
comando . Modificare gli argomenti se l'app ha una struttura di cartelle diversa.Passare la cartella corrente (
src
) e la cartella API (api
) all'interfaccia della riga di comando.swa start src --api-location api
Windows Firewall potrebbe richiedere che il runtime di Funzioni di Azure possa accedere a Internet. Seleziona Consenti.
All'avvio dell'interfaccia della riga di comando, accedere all'app all'indirizzo
http://localhost:4280/
. Si noti che la pagina chiama l'API e ne visualizza l'output,Hello from the API
.Per arrestare l'interfaccia della riga di comando, digitare CTRL+C.
Aggiungere la posizione API al flusso di lavoro
Prima di poter distribuire l'app in Azure, aggiornare il flusso di lavoro gitHub Actions del repository con il percorso corretto della cartella DELL'API.
Aprire il flusso di lavoro in .github/workflows/azure-static-web-apps-DEFAULT-HOSTNAME<>.yml.
Cercare la proprietà
api_location
e impostare il valore suapi
.###### Repository/Build Configurations - These values can be configured to match your app requirements. ###### # For more information regarding Static Web App workflow configurations, please visit: https://aka.ms/swaworkflowconfig app_location: "src" # App source code path api_location: "api" # Api source code path - optional output_location: "" # Built app content directory - optional ###### End of Repository/Build Configurations ######
Nota: i valori precedenti di
api_location
,app_location
output_location
non sono validi per alcun framework e questi valori cambiano in base al framework.Salvare il file.
Distribuire le modifiche
Per pubblicare le modifiche all'app Web statica in Azure, eseguire il commit e il push del codice nel repository GitHub remoto.
Premere F1 per aprire il riquadro comandi.
Selezionare il comando Git: Commit All (Git: Commit All ).
Quando viene richiesto un messaggio di commit, immettere feat: aggiungere l'API ed eseguire il commit di tutte le modifiche nel repository Git locale.
Premere F1 per aprire il riquadro comandi.
Selezionare il comando Git: push .
Le modifiche vengono inoltrate al repository remoto in GitHub, attivando il flusso di lavoro App Web statiche GitHub Actions per compilare e distribuire l'app.
Aprire il repository in GitHub per monitorare lo stato dell'esecuzione del flusso di lavoro.
Al termine dell'esecuzione del flusso di lavoro, visitare l'app Web statica per visualizzare le modifiche.