document/content/docs/introduction/guide/dashboard/workflow/http.mdx
import { Alert } from '@/components/docs/Alert';
HTTP 模块会向对应的地址发送一个 HTTP 请求,实际操作与 Postman 和 ApiFox 这类直流工具使用差不多。
{{}} 来引用变量。{{}} 来引用变量。全局变量、系统变量、前方节点输出你可以将鼠标放置在请求参数旁边的问号中,里面会提示你可用的变量。
不多描述,使用方法和Postman, ApiFox 基本一致。
可通过 {{key}} 来引入变量。例如:
| key | value |
|---|---|
| appId | {{appId}} |
| Authorization | Bearer {{token}} |
只有特定请求类型下会生效。
可以写一个自定义的 Json,并通过 {{key}} 来引入变量。例如:
<Tabs items={['假设有一组变量','Http 模块中的Body声明','最终得到的解析']}> <Tab value="假设有一组变量" >
{
"string": "字符串",
"number": 123,
"boolean": true,
"array": [1, 2, 3],
"obj": {
"name": "FastGPT",
"url": "https://fastgpt.io"
}
}
注意,在 Body 中,你如果引用字符串,则需要加上"",例如:"{{string}}"。
{
"string": "{{string}}",
"token": "Bearer {{string}}",
"number": {{number}},
"boolean": {{boolean}},
"array": [{{number}}, "{{string}}"],
"array2": {{array}},
"object": {{obj}}
}
{
"string": "字符串",
"token": "Bearer 字符串",
"number": 123,
"boolean": true,
"array": [123, "字符串"],
"array2": [1, 2, 3],
"object": {
"name": "FastGPT",
"url": "https://fastgpt.io"
}
}
从图中可以看出,FastGPT可以添加多个返回值,这个返回值并不代表接口的返回值,而是代表如何解析接口返回值,可以通过 JSON path 的语法,来提取接口响应的值。
语法可以参考: https://github.com/JSONPath-Plus/JSONPath?tab=readme-ov-file
<Tabs items={['接口响应示例','提取示例']}> <Tab value="接口响应示例" >
{
"message": "测试",
"data":{
"user": {
"name": "xxx",
"age": 12
},
"list": [
{
"name": "xxx",
"age": 50
},
[{ "test": 22 }]
],
"psw": "xxx"
}
}
{
"$.message": "测试",
"$.data.user": { "name": "xxx", "age": 12 },
"$.data.user.name": "xxx",
"$.data.user.age": 12,
"$.data.list": [ { "name": "xxx", "age": 50 }, [{ "test": 22 }] ],
"$.data.list[0]": { "name": "xxx", "age": 50 },
"$.data.list[0].name": "xxx",
"$.data.list[0].age": 50,
"$.data.list[1]": [ { "test": 22 } ],
"$.data.list[1][0]": { "test": 22 },
"$.data.list[1][0].test": 22,
"$.data.psw": "xxx"
}
你可以配置对应的key来从FastGPT 转化后的格式获取需要的值,该规则遵守 JS 的对象取值规则。例如:
message的内容,那么你可以配置message的key为message,这样就可以获取到message的内容。user的name,则key可以为:data.user.name。key可以为:data.list[1],然后输出类型选择字符串,则获自动获取到[ { "test": 22 } ]的json字符串。FastGPT v4.6.8 后,加入了出参格式化功能,主要以json格式化成字符串为主。如果你的输出类型选择了字符串,则会将HTTP对应key的值,转成json字符串进行输出。因此,未来你可以直接从HTTP接口输出内容至文本加工中,然后拼接适当的提示词,最终输入给AI对话。
如果你不想额外部署服务,可以使用 Laf 来快速开发上线接口,即写即发,无需部署。 </Alert>
下面是在 Laf 编写的 POST 请求示例:
import cloud from '@lafjs/cloud'
const db = cloud.database()
type RequestType = {
appId: string;
appointment: string;
action: 'post' | 'delete' | 'put' | 'get'
}
export default async function (ctx: FunctionContext) {
try {
// 从 body 中获取参数
const { appId, appointment, action } = ctx.body as RequestType
const parseBody = JSON.parse(appointment)
if (action === 'get') {
return await getRecord(parseBody)
}
if (action === 'post') {
return await createRecord(parseBody)
}
if (action === 'put') {
return await putRecord(parseBody)
}
if (action === 'delete') {
return await removeRecord(parseBody)
}
return {
response: "异常"
}
} catch (err) {
return {
response: "异常"
}
}
}
通过 HTTP 模块你可以无限扩展,比如: