Swagger API 代理:智能 API 查询与调用 - Openclaw Skills
作者:互联网
2026-03-27
什么是 Swagger API 智能工具?
swagger-skill 是连接 AI 智能体与 RESTful 服务之间的强大桥梁,旨在简化与 API 文档的交互。作为 Openclaw Skills 生态系统的核心组件,该工具允许开发者和智能体跳过手动浏览文档的过程。它能自动解析 Swagger 2.0 和 OpenAPI 3.0 规范,提供一个可搜索、可执行的接口。
通过利用自然语言处理技术,此技能可以将用户意图匹配到特定的 API 端点,处理复杂的参数映射,并管理身份验证状态。无论您是在调试新服务还是自动化数据检索,此技能都提供了一种开发者友好的方式,在无需编写重复样板代码的情况下与任何标准 API 规范进行交互。
下载入口:https://github.com/openclaw/skills/tree/main/skills/minusgod/swagger-skill
安装与下载
1. ClawHub CLI
从源直接安装技能的最快方式。
npx clawhub@latest install swagger-skill
2. 手动安装
将技能文件夹复制到以下位置之一
全局模式~/.openclaw/skills/
工作区
/skills/
优先级:工作区 > 本地 > 内置
3. 提示词安装
将此提示词复制到 OpenClaw 即可自动安装。
请帮我使用 Clawhub 安装 swagger-skill。如果尚未安装 Clawhub,请先安装(npm i -g clawhub)。
Swagger API 智能工具 应用场景
- 在 Openclaw Skills 中使用人类可读的指令自动发现并调用 API 端点。
- 快速搜索大型 Swagger 文件,通过标签或摘要查找特定功能。
- 通过统一接口处理复杂的多部分文件上传和 JSON 请求。
- 直接从命令行环境自动化 API 测试和集成任务。
- 该技能从提供的 URL 或本地路径获取并解析 Swagger 或 OpenAPI 规范。
- 它构建分层缓存,创建一个用于快速搜索的轻量级索引和一个用于完整 Schema 访问的详细映射。
- 处理用户指令,根据关键词和语义匹配识别最相关的 API 路径和 HTTP 方法。
- 该技能通过按配置将令牌或 Cookie 注入请求头来管理身份验证。
- 它使用 axios 执行网络请求,并向智能体或用户返回结构化响应。
Swagger API 智能工具 配置指南
此技能旨在易于使用。在首次运行时,会自动检测并安装 axios 和 form-data 等依赖项。如需手动安装,请使用以下命令:
npm install
要启动用于测试 Openclaw Skills 集成的交互式命令行界面:
node cli.js
Swagger API 智能工具 数据架构与分类体系
该技能使用以下结构组织其内部状态和缓存,以确保高性能:
| 数据组件 | 描述 |
|---|---|
| apiIndex | 包含路径、方法、摘要和标签的轻量级索引,用于 O(n) 搜索。 |
| apiDetailMap | 基于 Map 的存储,用于 O(1) 查找完整端点详情和 Schema。 |
| authStore | 封装 JWT 令牌、自定义请求头和 Cookie 配置。 |
| sessionContext | 管理唯一的会话 ID 和缓存刷新生命周期。 |
name: swagger-skill
description: 智能 Swagger API 查询和调用工具。通过自然语言指令直接查询接口详情、调用 API,无需繁琐的交互步骤。
metadata:
clawdbot:
emoji: "???"
requires:
bins: ["node"]
功能特性
- 一键查询: 直接查询接口详情,自动解析参数、请求体、响应模式
- 自然语言搜索: 根据自然语言描述找到匹配的接口(如"保存用户"、"获取数据集列表"),支持 tags 匹配
- 智能接口调用: 根据自然语言指令自动匹配并调用相应的 API
- 完整信息展示: 自动获取并展示接口的完整信息(参数、请求体、响应、数据模式定义)
- 文件上传支持: 支持 multipart/form-data 文件上传
- 分层缓存: 轻量索引用于列表/搜索,Map 结构 O(1) 详情查找
- Swagger 2.0 兼容: 同时支持 OpenAPI 3.0 和 Swagger 2.0 规范
- 灵活认证: 支持 Token、Cookie 或无需验证的多种认证方式
安装
无需手动安装依赖。首次使用时会自动检测并安装所需依赖(axios、form-data),同时自动初始化 package.json(含 "type": "module" 配置)。
如需手动安装,可在 skill 目录下执行:
npm install
使用方法
基础使用
import SwaggerAPISkill from './index.js';
const skill = new SwaggerAPISkill();
// 1. 加载 Swagger 规范
await skill.fetchSwaggerSpec('https://api.example.com/swagger.json');
// 2. 获取所有接口
const allAPIs = skill.getAllAPIs();
// 3. 搜索接口
const results = skill.searchAPI('获取用户信息');
// 4. 获取接口详情
const detail = skill.getAPIDetail('/users/{id}', 'GET');
// 5. 调用接口
const response = await skill.callAPI('/users', 'GET', {
query: { page: 1, limit: 10 }
});
// 6. 通过自然语言指令调用
const result = await skill.callAPIByInstruction('获取所有用户', {
query: { page: 1 }
});
认证方法
方法 1: 使用 Token 认证
import SwaggerAPISkill from './index.js';
const skill = new SwaggerAPISkill();
// 方式 A: 先设置 Token,再加载规范
skill.setAuthToken('your-jwt-token');
await skill.fetchSwaggerSpec('http://localhost:8090/v2/api-docs');
// 方式 B: 在加载规范时直接传入 Token
await skill.fetchSwaggerSpec('http://localhost:8090/v2/api-docs', {
token: 'your-jwt-token',
tokenOptions: {
tokenType: 'Bearer',
headerName: 'Authorization'
}
});
// 调用 API(会自动添加认证头)
const result = await skill.callAPI('/sysUser/list', 'POST', {
body: { pageNum: 1, pageSize: 10 }
});
方法 2: 使用 Cookie 认证
const skill = new SwaggerAPISkill();
// 方式 A: 先设置 Cookie,再加载规范
skill.setAuthCookies({
token: 'your-token',
JSESSIONID: 'your-session-id'
});
await skill.fetchSwaggerSpec('http://localhost:8090/v2/api-docs');
// 方式 B: 在加载规范时直接传入 Cookie
await skill.fetchSwaggerSpec('http://localhost:8090/v2/api-docs', {
cookies: {
token: 'your-token',
JSESSIONID: 'your-session-id'
}
});
方法 3: 无需认证
const skill = new SwaggerAPISkill();
// 直接加载规范
await skill.fetchSwaggerSpec('http://localhost:8090/v2/api-docs');
// 调用 API
const result = await skill.callAPI('/users', 'GET', {
query: { page: 1, limit: 10 }
});
方法 4: 使用 CLI 工具(推荐)
node cli.js
交互式 CLI 工具会引导你:
- 输入 Swagger API 文档 URL
- 输入认证 Token(可选)
- 通过菜单选择操作(获取接口列表、搜索、调用等)
API 文档
fetchSwaggerSpec(url, options)
获取并加载 Swagger 规范文件。
参数:
url(string): Swagger JSON URL 或 API 基础 URLoptions(object): 可选配置token(string): JWT Token 或其他认证 Tokencookies(object): Cookie 对象,如{ token: 'xxx', JSESSIONID: 'xxx' }tokenOptions(object): Token 选项tokenType(string): Token 类型,默认为 'Bearer'headerName(string): 请求头名称,默认为 'Authorization'
返回:
{
success: boolean,
apiCount?: number, // 接口总数
cached?: boolean, // 仅缓存命中时返回 true
error?: string
}
setAuthToken(token, options)
设置认证 Token。
参数:
token(string): JWT Token 或其他认证 Tokenoptions(object): 可选配置tokenType(string): Token 类型,默认为 'Bearer'headerName(string): 请求头名称,默认为 'Authorization'
返回:
{
success: boolean,
message: string
}
setAuthCookies(cookies)
设置认证 Cookie。
参数:
cookies(object): Cookie 对象,如{ token: 'xxx', JSESSIONID: 'xxx' }
返回:
{
success: boolean,
message: string
}
clearAuth()
清除认证信息。
返回:
{
success: boolean,
message: string
}
getAllAPIs()
获取所有接口的基本信息。
返回:
{
success: boolean,
total: number,
apis: Array<{
path: string,
method: string,
summary: string,
description: string,
operationId: string,
tags: string[]
}>
}
searchAPI(query)
根据自然语言查询搜索接口。支持 summary、description、path、operationId 和 tags 匹配。
参数:
query(string): 自然语言查询字符串
返回:
{
success: boolean,
query: string,
matchCount: number,
results: Array<{
path: string,
method: string,
summary: string,
description?: string, // 仅非空时返回
score: number
}>
}
getAPIDetail(path, method)
获取特定接口的详细信息。使用 Map O(1) 查找。
参数:
path(string): API 路径,如/users/{id}method(string): HTTP 方法,如GET,POST等
返回:
{
success: boolean,
detail?: {
path: string,
method: string,
summary: string,
description: string,
parameters: Array,
requestBody: object,
responses: object,
tags: Array
},
error?: string
}
getFullAPIDetail(path, method)
获取完整的接口详情,包括关联的数据模式定义。兼容 OpenAPI 3.0 和 Swagger 2.0。
参数:
path(string): API 路径method(string): HTTP 方法
返回:
{
success: boolean,
detail?: {
path: string,
method: string,
summary: string,
description: string,
parameters: Array,
requestBody: object,
responses: object,
tags: Array,
relatedSchemas: object, // 关联的数据模式定义
schemaCount: number
},
error?: string
}
callAPI(path, method, params)
调用 API 接口。支持 JSON 请求和 multipart/form-data 文件上传。
参数:
path(string): API 路径method(string): HTTP 方法params(object): 请求参数query(object): 查询参数body(object): 请求体(JSON 或 FormData)headers(object): 自定义请求头isFormData(boolean): 是否为 FormData(文件上传)
返回:
{
success: boolean,
status?: number,
data?: any,
error?: string
}
示例 - JSON 请求:
const response = await skill.callAPI('/api/users', 'POST', {
body: { name: 'John', email: 'john@example.com' }
});
示例 - 文件上传(使用 FormData):
import FormData from 'form-data';
import fs from 'fs';
const form = new FormData();
form.append('file', fs.createReadStream('./data.jsonl'));
form.append('name', 'My Dataset');
form.append('type', 'train_data');
const response = await skill.callAPI('/api/datasets/', 'POST', {
body: form,
isFormData: true
});
callAPIByInstruction(instruction, params)
根据自然语言指令调用 API。
参数:
instruction(string): 自然语言指令params(object): 请求参数(同 callAPI)
返回:
{
success: boolean,
instruction: string,
matchedAPI?: {
path: string,
method: string,
summary: string,
matchScore: number
},
result: object,
error?: string
}
uploadFile(path, formData, query)
文件上传方法,支持 multipart/form-data。
参数:
path(string): API 路径formData(object): 表单数据对象file: 文件内容(Buffer)或文件路径(string)- 其他字段: 表单字段(自动转换为字符串)
query(object): 查询参数(可选)
返回:
{
success: boolean,
status?: number,
data?: any,
error?: string
}
示例:
import SwaggerAPISkill from './index.js';
const skill = new SwaggerAPISkill();
await skill.fetchSwaggerSpec('http://localhost:8000/openapi.json');
// 方式1: 使用文件路径
const result1 = await skill.uploadFile('/api/datasets/', {
file: './test_dataset.jsonl',
name: 'AI知识问答对',
type: 'train_data',
description: '人工智能相关的问答对数据集'
});
// 方式2: 使用 Buffer
import fs from 'fs';
const fileBuffer = fs.readFileSync('./test_dataset.jsonl');
const result2 = await skill.uploadFile('/api/datasets/', {
file: fileBuffer,
name: 'AI知识问答对',
type: 'train_data',
description: '人工智能相关的问答对数据集'
});
getSessionId()
获取当前会话ID。
返回:
string // 唯一的会话ID,格式: session_timestamp_randomId
refreshSession()
刷新会话,清空所有缓存数据。
返回:
{
success: boolean,
message: string
}
缓存机制
swagger-skill 实现了分层缓存来优化性能和 token 消耗:
- 轻量索引 (apiIndex): 仅存储 path/method/summary/description/operationId/tags,用于
getAllAPIs()和searchAPI() - 详情 Map (apiDetailMap):
"METHOD /path" → 完整详情,用于getAPIDetail()的 O(1) 查找 - 首次加载: 调用
fetchSwaggerSpec()时从远程获取规范并构建两层缓存 - 后续查询: 所有查询操作直接使用内存缓存,无需重新加载
- 会话管理: 调用
refreshSession()可清空缓存
支持的 HTTP 方法
- GET
- POST
- PUT
- DELETE
- PATCH
- HEAD
- OPTIONS
注意事项
- 需要网络连接来获取 Swagger 规范和调用 API
- 某些 API 可能需要身份验证,可通过
headers参数传递认证信息 - 自然语言搜索基于关键词匹配,支持 summary、description、path、operationId 和 tags
- 路径参数需要在
query参数中提供 - 文件上传:
- 使用
uploadFile()方法是最简单的方式,支持文件路径或 Buffer - 也可以使用
callAPI()方法配合 FormData 对象进行更灵活的控制 - 文件上传时不需要手动设置 Content-Type,会自动设置为 multipart/form-data
- 使用
- 同时兼容 OpenAPI 3.0 (
components.schemas) 和 Swagger 2.0 (definitions)
许可证
MIT
相关推荐
专题
+ 收藏
+ 收藏
+ 收藏
+ 收藏
+ 收藏
最新数据
相关文章
会话成本追踪器:优化 Token 投资回报率 - Openclaw Skills
Memoria: AI 智能体结构化记忆系统 - Openclaw Skills
Deno 运行时专家:安全 TypeScript 开发 - Openclaw Skills
为 AI 代理部署 Spark Bitcoin L2 代理 - Openclaw Skills
加密货币价格技能:实时市场数据集成 - Openclaw Skills
Happenstance:专业人脉搜索与研究 - Openclaw Skills
飞书日历技能:通过 Openclaw Skills 自动化日程安排
顾问委员会:多人格 AI 加密货币分析 - Openclaw Skills
CRIF:面向 AI Agent 的加密深度研究框架 - Openclaw Skills
个人社交:社交生活与生日助手 - Openclaw Skills
AI精选
