Dela via


Lägga till ett API i Azure Static Web Apps med Azure Functions

Du kan lägga till serverlösa API:er i Azure Static Web Apps som drivs av Azure Functions. Den här artikeln visar hur du lägger till och distribuerar ett API till en Azure Static Web Apps-webbplats.

Kommentar

Funktionerna som tillhandahålls som standard i Static Web Apps är förkonfigurerade för att tillhandahålla säkra API-slutpunkter och stöder endast HTTP-utlösta funktioner. Mer information om hur de skiljer sig från fristående Azure Functions-appar finns i API-stöd med Azure Functions .

Förutsättningar

Dricks

Du kan använda nvm-verktyget för att hantera flera versioner av Node.js i ditt utvecklingssystem. I Windows kan NVM för Windows installeras via Winget.

Skapa den statiska webbappen

Innan du lägger till ett API skapar och distribuerar du ett klientdelsprogram till Azure Static Web Apps genom att följa snabbstarten Skapa din första statiska webbplats med Azure Static Web Apps .

När du har distribuerat ett klientdelsprogram till Azure Static Web Apps klonar du din applagringsplats. Du kan till exempel klona lagringsplatsen med hjälp av kommandoraden git .

Innan du kör följande kommando måste du ersätta <YOUR_GITHUB_USERNAME> med ditt GitHub-användarnamn.

git clone https://github.com/<YOUR_GITHUB_USERNAME>/my-first-static-web-app

Öppna roten för appens lagringsplats i Visual Studio Code. Mappstrukturen innehåller källan för klientdelsappen och GitHub-arbetsflödet för Static Web Apps i mappen .github/workflows .

├── .github
│   └── workflows
│       └── azure-static-web-apps-<DEFAULT_HOSTNAME>.yml
│
└── (folders and files from your static web app)

Skapa API:et

Du skapar ett Azure Functions-projekt för din statiska webbapps API. Som standard skapar Visual Studio Code-tillägget Static Web Apps projektet i en mapp med namnet API i roten på lagringsplatsen.

  1. Tryck på F1 för att öppna kommandopaletten.

  2. Välj Azure Static Web Apps: Skapa HTTP-funktion.... Om du uppmanas att installera Azure Functions-tillägget installerar du det och kör det här kommandot igen.

  3. När du uppmanas till det anger du följande värden:

    Prompt Värde
    Välj ett språk JavaScript
    Välj en programmeringsmodell V4
    Ange ett funktionsnamn meddelande

    Dricks

    Du kan lära dig mer om skillnaderna mellan programmeringsmodeller i utvecklarguiden för Azure Functions

    Ett Azure Functions-projekt genereras med en HTTP-utlöst funktion. Din app har nu en projektstruktur som liknar följande exempel.

    ├── .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)
    
  4. Ändra message sedan funktionen för att returnera ett meddelande till klientdelen. Uppdatera funktionen i src/functions/message.js med följande kod.

    const { app } = require('@azure/functions');
    
    app.http('message', {
        methods: ['GET', 'POST'],
        authLevel: 'anonymous',
        handler: async (request, context) => {
            return { body: `Hello, from the API!` };
        }
    });
    

Dricks

Du kan lägga till fler API-funktioner genom att köra kommandot Azure Static Web Apps: Skapa HTTP-funktion... igen.

Uppdatera klientdelsappen för att anropa API:et

Uppdatera klientdelsappen för att anropa API:et och /api/message visa svarsmeddelandet.

Om du använde snabbstarterna för att skapa appen använder du följande instruktioner för att tillämpa uppdateringarna.

Uppdatera innehållet i src/index.html-filen med följande kod för att hämta texten från API-funktionen och visa den på skärmen.

<!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>

Kör klientdelen och API:et lokalt

Om du vill köra klientdelsappen och API:et tillsammans lokalt tillhandahåller Azure Static Web Apps ett CLI som emulerar molnmiljön. CLI använder Azure Functions Core Tools för att köra API:et.

Installera kommandoradsverktyg

Se till att du har de nödvändiga kommandoradsverktygen installerade.

Viktigt!

För att förbättra säkerheten för distributioner från Static Web Apps CLI infördes en icke-bakåtkompatibel ändring som kräver att du uppgraderar till den senaste versionen (2.0.2) av Static Web Apps CLI senast den 15 januari 2025.

npm install -g @azure/static-web-apps-cli

Dricks

Om du inte vill installera kommandoraden swa globalt kan du använda npx swa i stället för swa i följande instruktioner.

Skapa klientdelsapp

Om din app använder ett ramverk skapar du appen för att generera utdata innan du kör Static Web Apps CLI.

Du behöver inte skapa appen.

Köra appen lokalt

Kör klientdelsappen och API:et tillsammans genom att starta appen med Static Web Apps CLI. Genom att köra de två delarna av programmet på det här sättet kan CLI hantera klientdelens byggutdata från en mapp och göra API:et tillgängligt för appen som körs.

  1. Starta Static Web Apps CLI med kommandot i roten start på lagringsplatsen. Justera argumenten om din app har en annan mappstruktur.

    Skicka den aktuella mappen (src) och API-mappen (api) till CLI.

    swa start src --api-location api
    
  2. Windows-brandväggen kan uppmanas att begära att Azure Functions-körningen kan komma åt Internet. Markera Tillåt.

  3. När CLI-processerna startar får du åtkomst till din app på http://localhost:4280/. Observera hur sidan anropar API:et och visar dess utdata, Hello from the API.

  4. Om du vill stoppa CLI skriver du Ctrl + C.

Lägga till API-plats i arbetsflödet

Innan du kan distribuera din app till Azure uppdaterar du lagringsplatsens GitHub Actions-arbetsflöde med rätt plats för DIN API-mapp.

  1. Öppna arbetsflödet på .github/workflows/azure-static-web-apps-DEFAULT-HOSTNAME><.yml.

  2. Sök efter egenskapen api_location och ange värdet till api.

    ###### 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 ######
    

    Obs! Ovanstående värden api_location för ,app_location,output_location är för inget ramverk och dessa värden ändras baserat på ditt ramverk.

  3. Spara filen.

Distribuera ändringar

Om du vill publicera ändringar i din statiska webbapp i Azure checkar du in och push-överför koden till den fjärranslutna GitHub-lagringsplatsen.

  1. Tryck på F1 för att öppna kommandopaletten.

  2. Välj kommandot Git: Commit All (Git: Commit All).

  3. När du uppmanas att skicka ett incheckningsmeddelande anger du feat: lägg till API och checka in alla ändringar på din lokala git-lagringsplats.

  4. Tryck på F1 för att öppna kommandopaletten.

  5. Välj kommandot Git: push.

    Dina ändringar skickas till fjärrlagringsplatsen i GitHub, vilket utlöser GitHub Actions-arbetsflödet för Static Web Apps för att skapa och distribuera din app.

  6. Öppna lagringsplatsen i GitHub för att övervaka statusen för din arbetsflödeskörning.

  7. När arbetsflödet körs går du till din statiska webbapp för att visa dina ändringar.

Nästa steg