5.9b HTTP API 参考
💡 一句话总结:OpenCode 服务器提供完整的 REST API,支持编程方式与 OpenCode 交互。
📝 课程笔记
本课核心知识点整理:

学完你能做什么
- 理解 OpenCode API 的整体结构
- 使用 API 管理会话和消息
- 通过 API 执行命令和操作文件
- 监听 SSE 事件流
API 概览
OpenCode 服务器发布 OpenAPI 3.1 规范,可在以下地址查看交互式文档:
http://<hostname>:<port>/doc例如:http://localhost:4096/doc
全局 API
/global
| 方法 | 路径 | 描述 | 响应 |
|---|---|---|---|
GET | /global/health | 服务器健康状态 | { healthy: true, version: string } |
GET | /global/event | 全局事件流(SSE) | Event stream |
示例:
# 检查服务器健康状态
curl http://localhost:4096/global/health响应:
{
"healthy": true,
"version": "1.0.48"
}来源:
opencode/packages/opencode/src/server/server.ts:131-150
项目 API
/project
| 方法 | 路径 | 描述 | 响应 |
|---|---|---|---|
GET | /project | 列出所有项目 | Project[] |
GET | /project/current | 获取当前项目 | Project |
来源:
opencode/packages/web/src/content/docs/server.mdx:88-94
路径与版本控制 API
/path, /vcs
| 方法 | 路径 | 描述 | 响应 |
|---|---|---|---|
GET | /path | 获取当前路径 | Path |
GET | /vcs | 获取当前项目的 VCS 信息 | VcsInfo |
来源:
opencode/packages/web/src/content/docs/server.mdx:97-103
实例 API
/instance
| 方法 | 路径 | 描述 | 响应 |
|---|---|---|---|
POST | /instance/dispose | 销毁当前实例 | boolean |
来源:
opencode/packages/web/src/content/docs/server.mdx:106-111
配置 API
/config
| 方法 | 路径 | 描述 | 响应 |
|---|---|---|---|
GET | /config | 获取配置信息 | Config |
PATCH | /config | 更新配置 | Config |
GET | /config/providers | 列出提供商和默认模型 | { providers: Provider[], default: Record<string, string> } |
来源:
opencode/packages/web/src/content/docs/server.mdx:114-121
提供商 API
/provider
| 方法 | 路径 | 描述 | 响应 |
|---|---|---|---|
GET | /provider | 列出所有提供商 | { all: Provider[], default: {...}, connected: string[] } |
GET | /provider/auth | 获取提供商认证方式 | { [providerID: string]: ProviderAuthMethod[] } |
POST | /provider/{id}/oauth/authorize | 发起 OAuth 授权 | ProviderAuthAuthorization |
POST | /provider/{id}/oauth/callback | 处理 OAuth 回调 | boolean |
来源:
opencode/packages/web/src/content/docs/server.mdx:124-132
会话 API
/session
这是最常用的 API,用于管理对话会话。
| 方法 | 路径 | 描述 | 备注 |
|---|---|---|---|
GET | /session | 列出所有会话 | 返回 Session[] |
POST | /session | 创建新会话 | body: { parentID?, title? } |
GET | /session/status | 获取所有会话状态 | { [sessionID: string]: SessionStatus } |
GET | /session/:id | 获取会话详情 | 返回 Session |
DELETE | /session/:id | 删除会话及其数据 | 返回 boolean |
PATCH | /session/:id | 更新会话属性 | body: { title? } |
GET | /session/:id/children | 获取子会话 | 返回 Session[] |
GET | /session/:id/todo | 获取会话的待办列表 | 返回 Todo[] |
POST | /session/:id/init | 分析应用并创建 AGENTS.md | body: { messageID, providerID, modelID } |
POST | /session/:id/fork | 从指定消息分叉会话 | body: { messageID? } |
POST | /session/:id/abort | 中止运行中的会话 | 返回 boolean |
POST | /session/:id/share | 分享会话 | 返回 Session |
DELETE | /session/:id/share | 取消分享 | 返回 Session |
GET | /session/:id/diff | 获取会话的文件差异 | query: messageID? |
POST | /session/:id/summarize | 总结会话 | body: { providerID, modelID } |
POST | /session/:id/revert | 还原消息 | body: { messageID, partID? } |
POST | /session/:id/unrevert | 恢复所有已还原的消息 | 返回 boolean |
POST | /session/:id/permissions/:permissionID | 响应权限请求 | body: { response, remember? } |
来源:
opencode/packages/web/src/content/docs/server.mdx:135-157
示例 - 创建新会话:
curl -X POST http://localhost:4096/session \
-H "Content-Type: application/json" \
-d '{"title": "代码审查会话"}'消息 API
/session/:id/message
| 方法 | 路径 | 描述 | 备注 |
|---|---|---|---|
GET | /session/:id/message | 列出消息 | query: limit? |
POST | /session/:id/message | 发送消息并等待响应 | body 见下方 |
GET | /session/:id/message/:messageID | 获取消息详情 | 返回 { info, parts } |
POST | /session/:id/prompt_async | 异步发送消息(不等待) | 返回 204 No Content |
POST | /session/:id/command | 执行斜杠命令 | body: { command, arguments, ... } |
POST | /session/:id/shell | 运行 shell 命令 | body: { agent, model?, command } |
发送消息的请求体
{
messageID?: string, // 可选,消息 ID
model?: string, // 可选,指定模型
agent?: string, // 可选,指定 agent
noReply?: boolean, // 可选,不等待回复
system?: string, // 可选,系统提示
tools?: string[], // 可选,启用的工具
parts: Part[] // 消息内容
}来源:
opencode/packages/web/src/content/docs/server.mdx:160-170
示例 - 发送消息:
curl -X POST http://localhost:4096/session/abc123/message \
-H "Content-Type: application/json" \
-d '{
"parts": [
{"type": "text", "text": "解释这段代码的作用"}
]
}'命令 API
/command
| 方法 | 路径 | 描述 | 响应 |
|---|---|---|---|
GET | /command | 列出所有命令 | Command[] |
来源:
opencode/packages/web/src/content/docs/server.mdx:173-178
文件 API
/find, /file
| 方法 | 路径 | 描述 | 响应 |
|---|---|---|---|
GET | /find?pattern=<pat> | 搜索文件内容 | 匹配结果数组 |
GET | /find/file?query=<q> | 按名称查找文件 | string[](路径) |
GET | /find/symbol?query=<q> | 查找工作区符号 | Symbol[] |
GET | /file?path=<path> | 列出目录内容 | FileNode[] |
GET | /file/content?path=<p> | 读取文件内容 | FileContent |
GET | /file/status | 获取已跟踪文件的状态 | File[] |
/find/file 查询参数
| 参数 | 必需 | 描述 |
|---|---|---|
query | 是 | 搜索字符串(模糊匹配) |
type | 否 | 限制为 "file" 或 "directory" |
directory | 否 | 覆盖项目根目录 |
limit | 否 | 最大结果数(1-200) |
dirs | 否 | 旧参数,"false" 只返回文件 |
来源:
opencode/packages/web/src/content/docs/server.mdx:181-199
示例 - 搜索文件:
# 搜索文件名包含 "config" 的文件
curl "http://localhost:4096/find/file?query=config&limit=10"
# 搜索文件内容
curl "http://localhost:4096/find?pattern=TODO"工具 API(实验性)
/experimental/tool
| 方法 | 路径 | 描述 | 响应 |
|---|---|---|---|
GET | /experimental/tool/ids | 列出所有工具 ID | ToolIDs |
GET | /experimental/tool?provider=<p>&model=<m> | 获取模型可用的工具及 JSON Schema | ToolList |
来源:
opencode/packages/web/src/content/docs/server.mdx:202-208
LSP、格式化器与 MCP API
/lsp, /formatter, /mcp
| 方法 | 路径 | 描述 | 响应 |
|---|---|---|---|
GET | /lsp | 获取 LSP 服务器状态 | LSPStatus[] |
GET | /formatter | 获取格式化器状态 | FormatterStatus[] |
GET | /mcp | 获取 MCP 服务器状态 | { [name: string]: MCPStatus } |
POST | /mcp | 动态添加 MCP 服务器 | body: { name, config } |
POST | /mcp/:name/auth | 启动 MCP OAuth 认证 | { authorizationUrl: string } |
POST | /mcp/:name/auth/callback | 处理 MCP OAuth 回调 | boolean |
来源:
opencode/packages/web/src/content/docs/server.mdx:211-218,server.ts:2197-2230
Agent API
/agent
| 方法 | 路径 | 描述 | 响应 |
|---|---|---|---|
GET | /agent | 列出所有可用 agent | Agent[] |
来源:
opencode/packages/web/src/content/docs/server.mdx:222-227
日志 API
/log
| 方法 | 路径 | 描述 | 响应 |
|---|---|---|---|
POST | /log | 写入日志条目 | boolean |
请求体:
{
service: string, // 服务名称
level: "debug" | "info" | "warn" | "error",
message: string, // 日志消息
extra?: Record<string, any> // 附加元数据
}来源:
opencode/packages/web/src/content/docs/server.mdx:230-235
TUI 控制 API
/tui
用于远程控制 TUI 界面,IDE 插件主要使用这些接口。
| 方法 | 路径 | 描述 | 响应 |
|---|---|---|---|
POST | /tui/append-prompt | 向提示框追加文本 | boolean |
POST | /tui/open-help | 打开帮助对话框 | boolean |
POST | /tui/open-sessions | 打开会话选择器 | boolean |
POST | /tui/open-themes | 打开主题选择器 | boolean |
POST | /tui/open-models | 打开模型选择器 | boolean |
POST | /tui/submit-prompt | 提交当前提示 | boolean |
POST | /tui/clear-prompt | 清空提示框 | boolean |
POST | /tui/execute-command | 执行命令 | body: { command } |
POST | /tui/show-toast | 显示提示通知 | body: { title?, message, variant } |
GET | /tui/control/next | 等待下一个控制请求 | Control request object |
POST | /tui/control/response | 响应控制请求 | body: { body } |
来源:
opencode/packages/web/src/content/docs/server.mdx:238-253
示例 - 远程控制 TUI:
# 向提示框添加文本
curl -X POST http://localhost:4096/tui/append-prompt \
-H "Content-Type: application/json" \
-d '{"text": "请帮我审查这段代码"}'
# 提交提示
curl -X POST http://localhost:4096/tui/submit-prompt
# 显示通知
curl -X POST http://localhost:4096/tui/show-toast \
-H "Content-Type: application/json" \
-d '{"message": "操作完成", "variant": "success"}'认证 API
/auth
| 方法 | 路径 | 描述 | 响应 |
|---|---|---|---|
PUT | /auth/:id | 设置认证凭据 | boolean |
请求体必须匹配对应提供商的 schema。
来源:
opencode/packages/web/src/content/docs/server.mdx:256-261
事件流 API
/event
| 方法 | 路径 | 描述 | 响应 |
|---|---|---|---|
GET | /event | SSE 事件流 | Server-sent events |
连接后,首先收到 server.connected 事件,之后是各种总线事件。
来源:
opencode/packages/web/src/content/docs/server.mdx:264-269
示例 - 监听事件:
curl -N http://localhost:4096/event输出示例:
event: server.connected
data: {}
event: session.created
data: {"id":"abc123","title":"新会话"}
event: message.created
data: {"sessionID":"abc123","content":"..."}API 文档
/doc
| 方法 | 路径 | 描述 | 响应 |
|---|---|---|---|
GET | /doc | OpenAPI 3.1 规范文档 | HTML 页面 |
来源:
opencode/packages/web/src/content/docs/server.mdx:272-277
类型定义
完整的 TypeScript 类型定义可在 SDK 中查看:
https://github.com/opencode-ai/opencode/blob/dev/packages/sdk/js/src/gen/types.gen.ts常用类型:
Session- 会话信息Message- 消息信息Part- 消息内容部分Provider- 提供商信息Agent- Agent 信息Config- 配置信息
踩坑提醒
| 现象 | 原因 | 解决 |
|---|---|---|
| 请求返回 CORS 错误 | 客户端来源未在白名单 | 启动时添加 --cors <origin> |
| 消息发送后无响应 | 使用了 prompt_async | 改用 /session/:id/message 同步接口 |
| SSE 连接频繁断开 | 网络超时或代理问题 | 检查代理设置,增加超时时间 |
| 404 错误 | 会话或消息 ID 不存在 | 先通过 GET 接口确认资源存在 |
| 实验性 API 不可用 | 功能可能变更或移除 | 查看最新文档确认 |
本课小结
你学会了:
- API 结构:19 个 API 分类,覆盖会话、消息、文件、工具等
- 会话管理:创建、查询、分叉、分享会话
- 消息交互:同步/异步发送消息,执行命令
- 文件操作:搜索、读取、列出文件
- TUI 控制:远程操控 TUI 界面
- 事件监听:通过 SSE 接收实时事件
相关资源
- 5.9a 远程模式基础 - 服务器启动与远程连接
- 5.10 SDK - JavaScript/TypeScript SDK
- 官方 API 文档 - 完整英文文档
下一课预告
下一课我们将学习如何使用 SDK 进行开发。

