你当前正在访问 Microsoft Azure Global Edition 技术文档网站。 如果需要访问由世纪互联运营的 Microsoft Azure 中国技术文档网站,请访问 https://docs.azure.cn。
在 Azure API 管理中将 Azure Function App 作为 API 导入
适用于:所有 API 管理层级
Azure API 管理支持将 Azure Function App 作为新 API 导入或将其追加到现有 API。 此过程会在 Azure Function App 中自动生成一个主机密钥,然后将其分配给 Azure API 管理中的命名值。
注意
目前无法在工作区中使用此功能。
本文详细介绍如何在 Azure API 管理中将 Azure Function App 作为 API 导入和测试。
可以了解如何执行以下操作:
- 将 Azure Function App 作为 API 导入
- 将 Azure Function App 追加到 API
- 查看新的 Azure Function App 主机密钥和 Azure API 管理命名值
- 在 Azure 门户中测试 API
先决条件
- 完成创建 Azure API 管理实例快速入门。
- 确保订阅中有 Azure Functions 应用。 有关详细信息,请参阅创建 Azure Function App。 函数必须将 HTTP 触发器和授权级别设置设为“匿名”或“函数”。
注意
可以使用 Visual Studio Code 的 API 管理扩展来导入和管理 API。 按照 API 管理扩展教程进行安装并开始使用。
转到你的 API 管理实例
在 Azure 门户中,搜索并选择“API 管理服务”。
在“API 管理”服务页上,选择你的 API 管理实例。
将 Azure Function App 作为新 API 导入
执行以下步骤,通过 Azure Function App 创建新的 API。
在 Azure 门户中导航到 API 管理服务,然后从菜单中选择“API”。
在“添加新 API”列表中,选择“Function App”。
单击“浏览”,选择要导入的 Functions。
单击“Function App”部分,从可用 Function App 的列表中进行选择。
找到要从其导入 Functions 的 Function App,然后单击它并按“选择”。
选择要导入的 Functions,然后单击“选择”。
- 只能使用“匿名”或“函数”授权级别导入基于 HTTP 触发器的函数。
切换到“完整”视图并将“产品”分配到新 API 。
如果需要,请在创建过程中指定其他字段,也可以稍后通过“设置”选项卡来配置这些字段。
- 在导入和发布第一个 API 教程中对这些设置进行了说明。
注意
产品是通过开发人员门户向开发人员提供的一个或多个 API 的关联。 首先,开发人员必须订阅产品才能访问 API。 订阅后,他们会得到一个订阅密钥,可用于该产品中的任何 API。 作为 API 管理实例的创建者,你默认成为管理员且订阅了每个产品。
每个 API 管理实例默认附带两个示例产品:
- 入门
- 不受限制
单击创建。
将 Azure Function App 追加到现有 API
执行以下步骤,将 Azure Function App 追加到现有 API。
在 Azure API 管理服务实例中,从左侧的菜单选择“API”。
选择要将 Azure Function App 导入到其中的 API。 单击“...”,并从上下文菜单中选择“导入”。
单击“Function App”磁贴。
在弹出窗口中,单击“浏览”。
单击“Function App”部分,从可用 Function App 的列表中进行选择。
找到要从其导入 Functions 的 Function App,然后单击它并按“选择”。
选择要导入的 Functions,然后单击“选择”。
单击“导入”。
Authorization
导入 Azure Function App 会自动生成:
- 主机密钥,该密钥位于 Function App 中,其名称为 apim-{你的 Azure API 管理服务实例名称};
- 命名值,该值位于 Azure API 管理实例中,其名称为 {你的 Azure Function App 实例名称}-key,其中包含创建的主机密钥。
对于 2019 年 4 月 4 日以后创建的 API,主机密钥将通过 HTTP 请求从 API 管理传递到标头中的 Function App。 较旧的 API 将主机密钥作为查询参数传递。 可以通过对与 Function App 关联的后端实体进行 PATCH Backend
REST API 调用来更改此行为。
警告
删除或更改 Azure Function App 主机密钥或 Azure API 管理命名值的值会导致服务之间的通信中断。 这些值不自动同步。
如需轮换主机密钥,请确保 Azure API 管理中的命名值也得到修改。
访问 Azure Function App 主机密钥
导航到 Azure Function App 实例。
在侧导航菜单的“函数”部分,选择“应用密钥”。
在“主机密钥”部分下方找到密钥。
访问 Azure API 管理中的命名值
导航到 Azure API 管理实例,然后在左侧菜单中选择“命名值”。 Azure Function App 密钥存储在该处。
在 Azure 门户中测试新的 API
可直接从 Azure 门户调用操作。 使用 Azure 门户可以方便地查看和测试 API 的操作。
选择在上一部分创建的 API。
选择“测试”选项卡。
选择要测试的操作。
- 该页将显示查询参数和标头的字段。
- 其中一个标头是“Ocp-Apim-Subscription-Key”,用于提供和此 API 关联的产品订阅密钥。
- 作为 API 管理实例的创建者,你已是管理员,因此会自动填充该密钥。
选择“发送”。
- 如果测试成功,后端以“200 正常”和某些数据做出响应。
相关主题
- API 导入限制
- 导入 OpenAPI 规范
- 导入 SOAP API
- 导入 SOAP API 并将其转换为 REST
- 导入应用服务 API
- 导入容器应用 API
- 导入 WebSocket API
- 导入 GraphQL API
- 导入 GraphQL 架构并设置字段解析程序
- 导入 Azure Function App
- 导入 Azure 逻辑应用
- 导入 Service Fabric 服务
- 导入 Azure OpenAI API
- 导入 OData API
- 导入 SAP OData 元数据
- 导入 gRPC API
- 编辑 API