使用 Azure Functions 將 API 新增至 Azure Static Web Apps
您可以將無伺服器 API 新增至由 Azure Functions 提供的 Azure Static Web Apps。 本文示範如何將 API 新增及部署至 Azure Static Web Apps 網站。
注意
靜態 Web Apps 中預設提供的函式已預先設定為提供安全的 API 端點,且僅支援 HTTP 觸發的函式。 如需與獨立 Azure Functions 應用程式有何不同的詳細資訊,請參閱 Azure Functions 的 API 支援。
必要條件
- 具有有效訂用帳戶的 Azure 帳戶。
- 如果您沒有帳戶,則可以免費建立帳戶。
- Visual Studio Code \(英文\)。
- 適用於 Visual Studio Code 的 Azure Static Web Apps 擴充功能 。
- 適用於 Visual Studio Code 的 Azure Functions 擴充功能。
- Node.js v18 來執行前端應用程式和 API。
提示
您可以使用 nvm 工具來管理開發系統上多個版本的Node.js。 在 Windows 上, 可以透過 Winget 安裝適用於 Windows 的 NVM。
建立靜態 Web 應用程式
新增 API 之前,請遵循 使用 Azure Static Web Apps 建置您的第一個靜態網站快速入門,建立前端應用程式並將其部署至 Azure Static Web Apps 。
將前端應用程式部署至 Azure Static Web Apps 之後, 請複製您的應用程式存放庫。 例如,您可以使用命令行複製存放庫 git
。
執行下列命令之前,請務必以您的 GitHub 使用者名稱取代 <YOUR_GITHUB_USERNAME>
。
git clone https://github.com/<YOUR_GITHUB_USERNAME>/my-first-static-web-app
在 Visual Studio Code 中,開啟您應用程式存放庫的根目錄。 資料夾結構包含前端應用程式的來源,以及 .github/workflows 資料夾中的靜態 Web Apps GitHub 工作流程。
├── .github
│ └── workflows
│ └── azure-static-web-apps-<DEFAULT_HOSTNAME>.yml
│
└── (folders and files from your static web app)
建立 API
您可以為靜態 Web 應用程式的 API 建立 Azure Functions 專案。 根據預設,Static Web Apps Visual Studio Code 擴充功能會在存放庫根目錄名為 api 的資料夾中建立專案。
按下 F1 以開啟 [命令選擇區]。
選取 [Azure 靜態 Web 應用程式:建立 HTTP 函式...]。如果系統提示您安裝 Azure Functions 擴充功能,請加以安裝並重新執行此命令。
當系統提示時,輸入下列值:
提示 值 選取語言 JavaScript 選取程式設計模型 V4 提供函式名稱 message 提示
您可以在 Azure Functions 開發人員指南中 深入瞭解程式設計模型之間的差異
使用 HTTP 觸發的函式產生 Azure Functions 專案。 您的應用程式現在有類似下列範例的項目結構。
├── .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)
接下來,變更 函式
message
以將訊息傳回前端。 使用下列程式代碼更新 src/functions/message.js 中的函式。const { app } = require('@azure/functions'); app.http('message', { methods: ['GET', 'POST'], authLevel: 'anonymous', handler: async (request, context) => { return { body: `Hello, from the API!` }; } });
提示
您可以執行 Azure Static Web Apps:再次建立 HTTP 函式... 命令,以新增更多 API 函式。
更新前端應用程式以呼叫 API
更新前端應用程式以呼叫 API, /api/message
並顯示回應訊息。
如果您使用快速入門來建立應用程式,請使用下列指示來套用更新。
使用下列程式代碼更新 src/index.html 檔案的內容,以從 API 函式擷取文字,並在畫面上顯示。
<!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>
在本機執行前端和 API
若要在本機一起執行前端應用程式和 API,Azure Static Web Apps 提供模擬雲端環境的 CLI。 CLI 會使用 Azure Functions Core Tools 來執行 API。
安裝命令列工具
請確定您已安裝必要的命令列工具。
重要
為了改善靜態 Web Apps CLI 部署的安全性,引進了重大變更,要求您在 2025 年 1 月 15 日之前升級至最新版的靜態 Web Apps CLI。
npm install -g @azure/static-web-apps-cli
提示
如果您不想全域安裝 swa
命令列,您可以在 npx swa
下列指示中使用,而不是 swa
。
建置前端應用程式
如果您的應用程式使用架構,請先建置應用程式以產生輸出,再執行靜態 Web Apps CLI。
在本機執行應用程式
使用靜態 Web Apps CLI 啟動應用程式,以一起執行前端應用程式和 API。 以這種方式執行應用程式的兩個部分可讓 CLI 從資料夾提供前端的組建輸出,並讓執行中的應用程式能夠存取 API。
在存放庫的根目錄中,使用
start
命令啟動 Static Web Apps CLI。 如果您的應用程式有不同的資料夾結構,請調整自變數。Windows 防火牆可能會提示要求 Azure Functions 運行時間可以存取因特網。 選取允許。
當 CLI 進程啟動時,請在
http://localhost:4280/
存取您的應用程式。 請注意頁面如何呼叫 API 並顯示其輸出Hello from the API
若要停止 CLI,請輸入 Ctrl + C。
將 API 位置新增至工作流程
將應用程式部署至 Azure 之前,請使用 API 資料夾的正確位置來更新存放庫的 GitHub Actions 工作流程。
在 .github/workflows/azure-static-web-apps-DEFAULT-HOSTNAME<> 開啟您的工作流程.yml。
搜尋 屬性
api_location
,並將值設定為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 ######
注意:、的上述值
api_location
app_location
output_location
不針對任何架構,且這些值會根據您的架構而變更。儲存檔案。
部署變更
若要在 Azure 中將變更發佈至靜態 Web 應用程式,請將程式代碼認可並推送至遠端 GitHub 存放庫。
按下 F1 以開啟 [命令選擇區]。
選取 [Git:認可全部] 命令。
當系統提示您輸入認可訊息時,請輸入 壯舉:新增API ,並將所有變更認可至本機 Git 存放庫。
按下 F1 以開啟 [命令選擇區]。
選取 Git:push 命令。
您的變更會推送至 GitHub 中的遠端存放庫,並觸發靜態 Web Apps GitHub Actions 工作流程來建置和部署您的應用程式。
在 GitHub 中開啟您的存放庫,以監視工作流程執行的狀態。
當工作流程執行完成時,請造訪靜態 Web 應用程式以檢視您的變更。