HTTP 模块

FastGPT HTTP 模块介绍

特点

  • 可重复添加
  • 手动配置
  • 触发执行
  • 核中核模块

HTTP 模块 - 图1

介绍

HTTP 模块会向对应的地址发送一个 HTTP 请求,实际操作与 Postman 和 ApiFox 这类直流工具使用差不多。

  • Params 为路径请求参数,GET请求中用的居多。
  • Body 为请求体,POST/PUT请求中用的居多。
  • Headers 为请求头,用于传递一些特殊的信息。
  • 自定义变量中可以接收前方节点的输出作为变量
  • 3 种数据中均可以通过 {{}} 来引用变量。
  • url 也可以通过 {{}} 来引用变量。
  • 变量来自于全局变量系统变量前方节点输出

参数结构

系统变量说明

你可以将鼠标放置在请求参数旁边的问号中,里面会提示你可用的变量。

  • appId: 应用的ID
  • chatId: 当前对话的ID,测试模式下不存在。
  • responseChatItemId: 当前对话中,响应的消息ID,测试模式下不存在。
  • variables: 当前对话的全局变量。
  • cTime: 当前时间。
  • histories: 历史记录(默认最多取10条,无法修改长度)

Params, Headers

不多描述,使用方法和Postman, ApiFox 基本一致。

可通过 {{key}} 来引入变量。例如:

keyvalue
appId{{appId}}
AuthorizationBearer {{token}}

Body

只有特定请求类型下会生效。

可以写一个自定义的 Json,并通过 {{key}} 来引入变量。例如:

假设有一组变量 Http 模块中的Body声明 最终得到的解析

  1. {
  2. "string": "字符串",
  3. "number": 123,
  4. "boolean": true,
  5. "array": [1, 2, 3],
  6. "obj": {
  7. "name": "FastGPT",
  8. "url": "https://fastgpt.in"
  9. }
  10. }

注意,在 Body 中,你如果引用字符串,则需要加上"",例如:"{{string}}"

  1. {
  2. "string": "{{string}}",
  3. "token": "Bearer {{string}}",
  4. "number": {{number}},
  5. "boolean": {{boolean}},
  6. "array": [{{number}}, "{{string}}"],
  7. "array2": {{array}},
  8. "object": {{obj}}
  9. }
  1. {
  2. "string": "字符串",
  3. "token": "Bearer 字符串",
  4. "number": 123,
  5. "boolean": true,
  6. "array": [123, "字符串"],
  7. "array2": [1, 2, 3],
  8. "object": {
  9. "name": "FastGPT",
  10. "url": "https://fastgpt.in"
  11. }
  12. }

如何获取返回值

从图中可以看出,FastGPT可以添加多个返回值,这个返回值并不代表接口的返回值,而是代表如何解析接口返回值,可以通过 key 来提取接口响应的值。例如:

接口响应格式 FastGPT 转化后的格式

  1. {
  2. "message": "测试",
  3. "data":{
  4. "user": {
  5. "name": "xxx",
  6. "age": 12
  7. },
  8. "list": [
  9. {
  10. "name": "xxx",
  11. "age": 50
  12. },
  13. [{ "test": 22 }]
  14. ],
  15. "psw": "xxx"
  16. }
  17. }
  1. {
  2. "message": "测试",
  3. "data.user": { "name": "xxx", "age": 12 },
  4. "data.user.name": "xxx",
  5. "data.user.age": 12,
  6. "data.list": [ { "name": "xxx", "age": 50 }, [{ "test": 22 }] ],
  7. "data.list[0]": { "name": "xxx", "age": 50 },
  8. "data.list[0].name": "xxx",
  9. "data.list[0].age": 50,
  10. "data.list[1]": [ { "test": 22 } ],
  11. "data.list[1][0]": { "test": 22 },
  12. "data.list[1][0].test": 22,
  13. "data.psw": "xxx"
  14. }

你可以配置对应的key来从FastGPT 转化后的格式获取需要的值,该规则遵守 JS 的对象取值规则。例如:

  1. 获取message的内容,那么你可以配置messagekeymessage,这样就可以获取到message的内容。
  2. 获取user的name,则key可以为:data.user.name
  3. 获取list中第二个元素,则key可以为:data.list[1],然后输出类型选择字符串,则获自动获取到[ { "test": 22 } ]json字符串。

自动格式化输出

FastGPT v4.6.8 后,加入了出参格式化功能,主要以json格式化成字符串为主。如果你的输出类型选择了字符串,则会将HTTP对应key的值,转成json字符串进行输出。因此,未来你可以直接从HTTP接口输出内容至文本加工中,然后拼接适当的提示词,最终输入给AI对话

warning

HTTP模块非常强大,你可以对接一些公开的API,来提高编排的功能。

如果你不想额外部署服务,可以使用 LafHTTP 模块 - 图2 来快速开发上线接口,即写即发,无需部署。

laf 对接 HTTP 示例

下面是在 Laf 编写的 POST 请求示例:

  1. import cloud from '@lafjs/cloud'
  2. const db = cloud.database()
  3. type RequestType = {
  4. appId: string;
  5. appointment: string;
  6. action: 'post' | 'delete' | 'put' | 'get'
  7. }
  8. export default async function (ctx: FunctionContext) {
  9. try {
  10. // 从 body 中获取参数
  11. const { appId, appointment, action } = ctx.body as RequestType
  12. const parseBody = JSON.parse(appointment)
  13. if (action === 'get') {
  14. return await getRecord(parseBody)
  15. }
  16. if (action === 'post') {
  17. return await createRecord(parseBody)
  18. }
  19. if (action === 'put') {
  20. return await putRecord(parseBody)
  21. }
  22. if (action === 'delete') {
  23. return await removeRecord(parseBody)
  24. }
  25. return {
  26. response: "异常"
  27. }
  28. } catch (err) {
  29. return {
  30. response: "异常"
  31. }
  32. }
  33. }

作用

通过 HTTP 模块你可以无限扩展,比如:

  • 操作数据库
  • 调用外部数据源
  • 执行联网搜索
  • 发送邮箱
  • ….

相关示例