n8n 工作流助手 - 通过 REST API 设计、创建、修改和管理 n8n 工作流。适合:自动化工程师、DevOps、流程编排。
通过 n8n REST API 设计、创建、修改和管理工作流。无需 MCP,纯 REST API 调用即可完全操控 n8n。
以下规则经过真实 n8n 2.x 实例验证,违反任一条都会导致 API 报错。
active 是只读字段 — 创建/更新时不传 activetagsstaticDatashared / activeVersion / pinData 是只读字段 — PUT 更新时不传POST /api/v1/workflows/{id}/activate(body: {})name/nodes/connections/settings,否则 must NOT have additional propertiesPATCH method not allowedresponseMode: "lastNode" 时,最后一个节点返回值自动作为 HTTP 响应,不要加 respondToWebhook 节点当用户请求以下操作时,自动激活此 Skill:
N8N_BASE_URL=http://localhost:5678
N8N_API_KEY=<your-api-key>
获取 API Key:n8n 界面 → Settings → API → Create an API Key
所有 API 请求必须携带:
X-N8N-API-KEY: <N8N_API_KEY>
Content-Type: application/json
curl -s -o /dev/null -w "%{http_code}" -H "X-N8N-API-KEY: $N8N_API_KEY" "$N8N_BASE_URL/api/v1/workflows"
200 → 正常 | 401 → Key 无效 | 000 → 网络不通Agent 必须严格遵循以下 4 阶段:
Step 1: 创建空骨架 → 获取 workflow_id
Step 2: 逐个添加节点(每次 1-3 个)
Step 3: 建立节点连接
Step 4: GET 验证完整工作流
Step 5: 激活(用户确认后)
{N8N_BASE_URL}/api/v1
| 操作 | 方法 | 端点 |
|---|---|---|
| 列表 | GET | /workflows?active=true&limit=50 |
| 详情 | GET | /workflows/{id} |
| 创建 | POST | /workflows |
| 更新 | PUT | /workflows/{id}(全量替换) |
| 删除 | DELETE | /workflows/{id} |
| 激活 | POST | /workflows/{id}/activate |
| 停用 | POST | /workflows/{id}/deactivate |
| 执行 | POST | /workflows/{id}/execute |
| 操作 | 方法 | 端点 |
|---|---|---|
| 列表 | GET | /credentials |
| 创建 | POST | /credentials |
| 操作 | 方法 | 端点 |
|---|---|---|
| 列表 | GET | /executions?workflowId={id}&status=error&limit=20 |
| 详情 | GET | /executions/{id} |
| 重试 | POST | /executions/{id}/retry |
# 列出所有工作流
curl -s -H "X-N8N-API-KEY: $N8N_API_KEY" "$N8N_BASE_URL/api/v1/workflows?limit=50"
# 获取单个工作流
curl -s -H "X-N8N-API-KEY: $N8N_API_KEY" "$N8N_BASE_URL/api/v1/workflows/123"
# 激活
curl.exe -s -X POST -H "X-N8N-API-KEY: $N8N_API_KEY" -H "Content-Type: application/json" -d "{}" "$N8N_BASE_URL/api/v1/workflows/123/activate"
# 停用
curl.exe -s -X POST -H "X-N8N-API-KEY: $N8N_API_KEY" "$N8N_BASE_URL/api/v1/workflows/123/deactivate"
# 删除
curl -s -X DELETE -H "X-N8N-API-KEY: $N8N_API_KEY" "$N8N_BASE_URL/api/v1/workflows/123"
# 手动执行
curl -s -X POST -H "X-N8N-API-KEY: $N8N_API_KEY" -H "Content-Type: application/json" -d '{"data": {"key": "value"}}' "$N8N_BASE_URL/api/v1/workflows/123/execute"
Windows 注意: PowerShell 的
curl是Invoke-WebRequest别名,用curl.exe调用真正的 curl。
{
"parameters": {},
"id": "unique-uuid",
"name": "Node Display Name",
"type": "n8n-nodes-base.xxx",
"typeVersion": 1,
"position": [250, 300],
"credentials": {},
"disabled": false
}
关键规则:
type 始终用完整格式 n8n-nodes-base.xxxid 用 UUID v4name 既是显示名称,也是 connections 中引用的 key{
"SourceNodeName": {
"main": [
[
{ "node": "TargetNodeName", "type": "main", "index": 0 }
]
]
}
}
三层嵌套:
{源节点} → {输出类型} → [[{目标列表}]]
常见模式:
线性(A→B→C):
{"A":{"main":[[{"node":"B","type":"main","index":0}]]}},
{"B":{"main":[[{"node":"C","type":"main","index":0}]]}}
分支(IF→true/false):
{"IF":{"main":[[{"node":"True","type":"main","index":0}],[{"node":"False","type":"main","index":0}]]}}
并行(A→B+C→D):
{"A":{"main":[[{"node":"B","type":"main","index":0},{"node":"C","type":"main","index":0}]]}}
在 parameters 中使用 ={{ }} 嵌入动态值。
| 变量 | 用途 | 示例 |
|---|---|---|
$json | 当前节点输入 | {{ $json.email }} |
$json.body | Webhook 请求体 | {{ $json.body.data }} |
$json.query | URL 查询参数 | {{ $json.query.page }} |
$node["Name"].json | 引用指定节点输出 | {{ $node["HTTP"].json.data }} |
$now | 当前时间 | {{ $now.toISO() }} |
$env | 环境变量 | {{ $env.MY_VAR }} |
$input.first() | 第一个输入项 | {{ $input.first().json.name }} |
Webhook 陷阱: POST 请求体在 $json.body 下,不是直接在 $json 下。
发送 JSON body 的正确配置:
{
"parameters": {
"sendBody": true,
"specifyBody": "json",
"jsonParameters": false,
"jsonBody": "={{ JSON.stringify({key: 'value'}) }}"
}
}
关键:jsonParameters: false 是必须的!设为 true 直接崩溃。
| 参数 | 值 | 说明 |
|---|---|---|
sendBody | true | 启用请求体 |
specifyBody | "json" | JSON 格式 |
jsonParameters | false | 必须为 false |
jsonBody | "={{ ... }}" | 用表达式传递 |
当需要 OpenClaw 定时自动触发 n8n 工作流时:
方法:直接编辑 jobs.json 文件
路径:$USER_HOME_PATH.openclaw\cron\jobs.json
在 jobs.json 中添加 cron 任务,通过 curl.exe POST 触发 n8n webhook URL。
关键经验:
通过 n8n 调用微信公众号草稿 API 时的限制:
| 限制项 | 字节数 | 中文数 | 说明 |
|---|---|---|---|
| title | ≤ 20字节 | ≤ 10个 | 超过报 45003 |
| digest | ≤ 54字节 | ≤ 25个 | 超过报 45004 |
| thumb_media_id | 不能为空 | — | 先上传封面获取 |
access_token 有效期 7200 秒,每次发草稿前重新获取,不缓存复用。
{
"settings": {
"executionOrder": "v1",
"errorWorkflow": "error-handler-workflow-id"
}
}
{
"name": "HTTP Request",
"continueOnFail": true
}
{
"type": "n8n-nodes-base.errorTrigger",
"typeVersion": 1
}
n8n-nodes-base.function(v1,已弃用),用 n8n-nodes-base.code(v2){
"name": "Webhook Echo",
"nodes": [
{
"id": "a1",
"name": "Webhook",
"type": "n8n-nodes-base.webhook",
"typeVersion": 2,
"position": [0, 0],
"parameters": {
"httpMethod": "POST",
"path": "echo",
"responseMode": "lastNode",
"responseData": "lastNode",
"options": {}
}
},
{
"id": "a2",
"name": "Process & Respond",
"type": "n8n-nodes-base.code",
"typeVersion": 2,
"position": [250, 0],
"parameters": {
"jsCode": "return [{ json: { received: $json.body, processed: true, time: new Date().toISOString() } }];"
}
}
],
"connections": {
"Webhook": { "main": [[{ "node": "Process & Respond", "type": "main", "index": 0 }]] }
},
"settings": { "saveManualExecutions": true, "executionOrder": "v1" }
}
激活 + 测试:
# 创建(自动获取 id)
# 激活(等 1-2 秒)
curl.exe -s -X POST -H "X-N8N-API-KEY: %N8N_API_KEY%" -H "Content-Type: application/json" -d "{}" "%N8N_BASE_URL%/api/v1/workflows/{id}/activate"
# 触发
curl.exe -s -X POST -H "Content-Type: application/json" -d "{\"hello\":\"world\"}" "%N8N_BASE_URL%/webhook/echo"
| 问题 | 原因 | 解决 |
|---|---|---|
| 401 | API Key 无效 | 重新生成 |
400 active is read-only | 传了 active | 不传,用 POST /activate |
400 tags is read-only | 传了 tags | 不传 |
400 must NOT have additional properties | PUT 传了额外字段 | 只传 name/nodes/connections/settings |
405 PATCH method not allowed | n8n 2.x 不支持 | 用 PUT 全量替换 |
500 Unused Respond to Webhook node | lastNode 模式下用了 respondToWebhook | 删掉,用 Code 节点返回 |
| Webhook 404 | 激活后立即触发 | 等 1-2 秒 |
| Wait 节点导致激活失败 | Wait for Callback 配置问题 | 用 Code + setTimeout 替代 |
| HTTP Request 崩溃 | jsonParameters: true | 改为 false |
| 微信 45003 | title 超字节 | title[:10] |
| 微信 45004 | digest 超字节 | digest[:25] |
| 微信草稿无封面 | thumb_media_id 为空 | 先上传获取 media_id |
| Webhook 路径 404 | 用了 path 参数而非 webhookId | 用 webhookId 触发 |
解决: 用 Code 节点 + await new Promise(r => setTimeout(r, 5000)) 替代
解决: 必须设为 false,true 直接崩溃
解决: title[:10] / digest[:25],每次发草稿前重新获取 token
解决: PUT 全量替换,必须包含全部节点
解决: n8n 2.x 用 {webhookId} 触发,不是 path 参数
解决: 停下来搜索文档/社区,分析根因,针对性解决
同一问题试错超过 3 次 → 必须停止:
ACTIVE=$(curl -s -H "X-N8N-API-KEY: $N8N_API_KEY" "$N8N_BASE_URL/api/v1/workflows?active=true" | jq ".data | length")
FAILED=$(curl -s -H "X-N8N-API-KEY: $N8N_API_KEY" "$N8N_BASE_URL/api/v1/executions?status=error&limit=100" | jq "[.data[] | select(.startedAt > (now - 86400 | todate))] | length")
echo "Active: $ACTIVE | Failed(24h): $FAILED"
python3 scripts/n8n_api.py list-workflows --active true --pretty
python3 scripts/n8n_api.py list-executions --limit 10 --pretty
python3 scripts/n8n_optimizer.py analyze --id <id> --pretty
python3 scripts/n8n_tester.py validate --id <id> --pretty