发出 HTTP 请求

在 Copilot Studio,您可以通过使用 HTTP 请求 节点调用外部 REST API 来扩展代理的功能。 需要从外部系统检索数据或操作该系统上的数据时,这可能会很有帮助。

先决条件

使用 HTTP 请求节点

  1. 选择添加节点+),打开高级子菜单,然后选择发送 HTTP 请求

    “高级”菜单中“发送 HTTP 请求”选项的屏幕截图。

  2. URL 框中,输入要调用的 API 端点的 URL。

  3. 从下拉列表中选择适当的请求方法。 支持 GET、POST、PATCH、PUT 和 DELETE 方法。

    完成的 API URL 和方法下拉列表的屏幕截图

  4. 在节点上的标题和正文下,选择编辑按钮,这将打开 HTTP 请求属性窗格。

  5. 您可以选择在 HTTP 请求中添加一个或多个标头。 选择添加按钮添加每个标头的关键字和值。

    HTTP 节点的标头键值对列表的屏幕截图。

  6. 默认情况下,HTTP 请求的正文中不发送任何内容,但您可以在正文中指定内容

  7. 在节点上,从可用选项中选择响应数据类型

    您可以提供一个示例 JSON 响应,通常可以在您调用的 API 的文档中找到。 它将生成一个 Power Fx 变量,允许您在创作画布的其他地方使用,并在 Power Fx 编辑器中提供智能感知支持。 选择从样本数据中,然后选择从样本 JSON 中获取架构。 将您的示例回答粘贴到编辑器中,然后选择确认

    来自示例 JSON 编辑器的 Get 模式的屏幕截图。

  8. 将响应另存为下,选择要存储 HTTP 请求响应的位置,创建一个新变量或选择一个现有变量。

在 HTTP 请求正文中发送内容

  1. 在节点上的标题和正文下,选择编辑按钮,这将打开 HTTP 请求属性窗格。

  2. 正文下,选择适当的内容类型。 默认情况下,正文被设置为无内容,其中请求正文中不应出现任何内容,这是 GET 请求最常用的方式。 要向正文添加内容,请从可用选项中选择一个。

    正文内容选项下拉列表的屏幕截图

    • JSON 内容:JSON 内容允许您在请求正文中提供一个 JSON 对象。 此对象通常在发出 POST 或 PUT 请求时使用。 选择该选项后,编辑器允许您输入 JSON 内容。

      您还可以使用 Power Fx 指定您的 JSON 内容,允许您包含动态值和引用变量。 选择编辑 JSON 按钮,选择公式,然后输入Power Fx对象(输入的任何现有 JSON 都将转换为 Power Fx 对象),当发出 HTTP 请求时,该对象将转换为 JSON。

      为正文内容类型选择的 JSON 内容的屏幕截图。

    • 原始内容:原始内容允许您在请求正文中插入一个数据字符串,该字符串可以是您指定的任何内容类型。 原始内容是使用 Power Fx 公式输入的,如以下示例中所示的字符串内容。

      为正文内容类型选择的原始内容的屏幕截图。

错误处理和超时

HTTP 请求节点有多个选项来处理 HTTP 请求可能失败或返回错误的情况。

默认情况下,该功能“引发错误”。这意味着,当 HTTP 请求返回错误或执行失败时,代理会停止其操作并触发 Error 系统主题,并显示错误消息。

但是,您可以将错误处理配置为不触发错误系统主题。 相反,它将 HTTP 状态代码和任何错误响应正文填充到您指定的变量中,允许您根据需要询问这些变量,并让主题继续运行。 在您希望代理继续操作的情况下,即使特定 HTTP 请求失败,此配置也很有用。

配置错误处理行为。

  1. 在节点上的标题和正文下,选择编辑按钮,这将打开 HTTP 请求属性窗格。

  2. 错误处理下拉列表中选择您想要的行为。

  3. 如果您选择出错时继续,请配置状态代码错误响应正文变量,创建新变量或从选取器中选择现有变量。

    错误处理的屏幕截图,配置为继续处理错误,并为状态代码和错误响应正文指定变量。

在此代码示例中,如果 HTTP 请求失败,则代理将 HTTP 状态代码存储在变量中 Topic.StatusCode ,并将回复正文存储在变量中 Topic.ErrorResponse 。 代理继续在主题中进行下一步。

错误响应变量类型为任何。 您可以使用解析值节点将此变量转换为 Power Fx 记录。

属性窗格还包含请求超时属性,该属性接受以毫秒为单位的值。 默认值为 30 秒,但如果需要,您可以更改该值。