# API 参考
**本文引用的文件**
- [src/index.ts](file://src/index.ts)
- [src/server.ts](file://src/server.ts)
- [src/websocket.ts](file://src/websocket.ts)
- [src/class/websockethandler.ts](file://src/class/websockethandler.ts)
- [src/class/httphandler.ts](file://src/class/httphandler.ts)
- [src/class/offer.ts](file://src/class/offer.ts)
- [src/class/answer.ts](file://src/class/answer.ts)
- [src/class/candidate.ts](file://src/class/candidate.ts)
- [src/swagger.ts](file://src/swagger.ts)
- [src/signaling.ts](file://src/signaling.ts)
- [client/src/signaling.js](file://client/src/signaling.js)
- [client/src/peer.js](file://client/src/peer.js)
- [test/websockethandler.test.ts](file://test/websockethandler.test.ts)
- [test/httphandler.test.ts](file://test/httphandler.test.ts)
- [package.json](file://package.json)
## 目录
1. [简介](#简介)
2. [项目结构](#项目结构)
3. [核心组件](#核心组件)
4. [架构总览](#架构总览)
5. [详细组件分析](#详细组件分析)
6. [依赖关系分析](#依赖关系分析)
7. [性能考量](#性能考量)
8. [故障排查指南](#故障排查指南)
9. [结论](#结论)
10. [附录](#附录)
## 简介
本文件为视频流服务器的完整 API 参考,覆盖以下内容:
- WebSocket 信令 API:连接建立、消息格式、事件类型与实时交互模式
- HTTP 轮询 API:端点规范、请求/响应格式、状态码与错误处理
- Swagger 自动化文档:生成与访问方式
- 信令消息数据结构:Offer、Answer、Candidate 等字段定义与使用场景
- 错误代码与处理指南
- API 使用示例与集成模板
## 项目结构
后端采用 Express 提供 HTTP 服务与静态资源,WebSocket 用于实时信令;HTTP 轮询模式通过 /signaling 路由提供信令存取能力。客户端提供基于 WebSocket 与 HTTP 轮询两种信令实现。
```mermaid
graph TB
subgraph "服务端"
A["Express 应用
src/server.ts"]
B["WebSocket 信令
src/websocket.ts"]
C["HTTP 轮询信令
src/signaling.ts → src/class/httphandler.ts"]
D["数据模型
src/class/offer.ts / answer.ts / candidate.ts"]
E["Swagger 文档
src/swagger.ts"]
end
subgraph "客户端"
F["信令封装(HTTP)
client/src/signaling.js"]
G["信令封装(WebSocket)
client/src/signaling.js"]
H["Peer 连接控制
client/src/peer.js"]
end
A --> B
A --> C
A --> E
B --> D
C --> D
F --> A
G --> B
H --> F
H --> G
```
图表来源
- [src/server.ts:14-89](file://src/server.ts#L14-L89)
- [src/websocket.ts:6-118](file://src/websocket.ts#L6-L118)
- [src/signaling.ts:1-25](file://src/signaling.ts#L1-L25)
- [src/class/httphandler.ts:1-1130](file://src/class/httphandler.ts#L1-L1130)
- [src/class/offer.ts:1-11](file://src/class/offer.ts#L1-L11)
- [src/class/answer.ts:1-8](file://src/class/answer.ts#L1-L8)
- [src/class/candidate.ts:1-12](file://src/class/candidate.ts#L1-L12)
- [src/swagger.ts:16-65](file://src/swagger.ts#L16-L65)
- [client/src/signaling.js:1-292](file://client/src/signaling.js#L1-L292)
- [client/src/peer.js:1-188](file://client/src/peer.js#L1-L188)
章节来源
- [src/server.ts:14-89](file://src/server.ts#L14-L89)
- [src/index.ts:13-109](file://src/index.ts#L13-L109)
## 核心组件
- 服务启动与配置:命令行参数解析、HTTPS/HTTP 选择、日志级别、信令协议类型与通信模式
- Express 服务:CORS、JSON/URL 编码、静态资源、/config、/signaling 路由挂载、Swagger 文档
- WebSocket 信令:连接生命周期、消息分发、广播、心跳与超时处理
- HTTP 轮询信令:会话管理、连接管理、Offer/Answer/Candidate 存取、房间与用户信息查询
- 数据模型:Offer、Answer、Candidate 结构体
- 客户端封装:HTTP 与 WebSocket 两类信令客户端,Peer 连接控制
章节来源
- [src/index.ts:13-109](file://src/index.ts#L13-L109)
- [src/server.ts:14-89](file://src/server.ts#L14-L89)
- [src/websocket.ts:6-118](file://src/websocket.ts#L6-L118)
- [src/class/websockethandler.ts:1-479](file://src/class/websockethandler.ts#L1-L479)
- [src/class/httphandler.ts:1-1130](file://src/class/httphandler.ts#L1-L1130)
- [src/class/offer.ts:1-11](file://src/class/offer.ts#L1-L11)
- [src/class/answer.ts:1-8](file://src/class/answer.ts#L1-L8)
- [src/class/candidate.ts:1-12](file://src/class/candidate.ts#L1-L12)
- [src/swagger.ts:16-65](file://src/swagger.ts#L16-L65)
- [src/signaling.ts:1-25](file://src/signaling.ts#L1-L25)
- [client/src/signaling.js:1-292](file://client/src/signaling.js#L1-L292)
- [client/src/peer.js:1-188](file://client/src/peer.js#L1-L188)
## 架构总览
系统支持两种信令模式:
- WebSocket:低延迟、全双工、事件驱动
- HTTP 轮询:兼容性好、部署简单、适合受限网络环境
```mermaid
sequenceDiagram
participant Client as "客户端"
participant Server as "Express 服务"
participant WS as "WebSocket 信令"
participant HTTP as "HTTP 轮询信令"
Client->>Server : GET /config
Server-->>Client : {useWebSocket, startupMode, logging}
alt WebSocket 模式
Client->>WS : 建立 ws/wss 连接
WS-->>Client : "connect"含 role/polite/participantId
Client->>WS : "offer"/"answer"/"candidate"
WS-->>Client : 广播/定向转发对应信令
else HTTP 模式
Client->>HTTP : PUT "" 创建会话返回 sessionId
Client->>HTTP : PUT "/connection" 创建连接
loop 轮询
Client->>HTTP : GET "" /offer /answer /candidate
HTTP-->>Client : 返回增量信令
end
Client->>HTTP : POST "/offer" /answer /candidate
Client->>HTTP : DELETE "" 关闭会话
end
```
图表来源
- [src/server.ts:25-41](file://src/server.ts#L25-L41)
- [src/websocket.ts:27-115](file://src/websocket.ts#L27-L115)
- [src/class/httphandler.ts:664-696](file://src/class/httphandler.ts#L664-L696)
- [src/class/httphandler.ts:698-828](file://src/class/httphandler.ts#L698-L828)
- [src/class/httphandler.ts:830-998](file://src/class/httphandler.ts#L830-L998)
- [src/signaling.ts:6-24](file://src/signaling.ts#L6-L24)
## 详细组件分析
### WebSocket 信令 API
- 连接建立
- 客户端通过 ws/wss 连接到服务端
- 服务端在连接事件中注册处理器,维护连接集合与连接组
- 消息格式与事件类型
- connect/disconnect:建立/断开连接,包含 connectionId、polite、role、participantId
- offer/answer/candidate:信令三元组,包含 from、to、data(含 sdp 或 candidate/sdpMid/sdpMLineIndex)、participantId
- ping/pong:心跳机制
- broadcast/on-message:广播消息与自定义消息
- participant-joined/participant-left:多参与者的房间模式事件
- 实时交互模式
- 公共模式:同一房间内广播
- 私有模式:host 与特定 participant 或 host 与其他 participants 之间定向转发
- 心跳与超时
- 服务端周期发送 ping,客户端回 pong;若长时间无活动则断开
```mermaid
sequenceDiagram
participant C as "客户端"
participant S as "WebSocket 信令"
participant H as "处理器(websockethandler)"
C->>S : "connect" {connectionId}
S->>H : onConnect(ws, connectionId)
H-->>C : "connect" {role, polite, participantId}
C->>S : "offer"/"answer"/"candidate"
S->>H : onOffer/onAnswer/onCandidate
H-->>C : 广播/定向转发对应信令
C->>S : "ping"
S-->>C : "pong"
S->>H : 更新 lastActivity
C->>S : "disconnect" {connectionId}
S->>H : onDisconnect
H-->>C : "disconnect"
```
图表来源
- [src/websocket.ts:44-115](file://src/websocket.ts#L44-L115)
- [src/class/websockethandler.ts:145-206](file://src/class/websockethandler.ts#L145-L206)
- [src/class/websockethandler.ts:214-338](file://src/class/websockethandler.ts#L214-L338)
- [src/class/websockethandler.ts:404-430](file://src/class/websockethandler.ts#L404-L430)
章节来源
- [src/websocket.ts:6-118](file://src/websocket.ts#L6-L118)
- [src/class/websockethandler.ts:1-479](file://src/class/websockethandler.ts#L1-L479)
### HTTP 轮询信令 API
- 会话与连接管理
- PUT "":创建会话,返回 sessionId
- DELETE "":删除会话
- PUT "/connection":创建连接,返回 connectionId、polite、type、datetime
- DELETE "/connection":删除连接
- 信令存取
- GET "":获取所有信令(connect/disconnect/offer/answer/candidate),按 datetime 排序
- GET "/offer":获取 offer 列表(可按 fromtime 过滤)
- GET "/answer":获取 answer 列表(可按 fromtime 过滤)
- GET "/candidate":获取 candidate 列表(可按 fromtime 过滤)
- GET "/connection":获取连接列表
- GET "/connection-ids":获取所有活跃连接 ID
- POST "/offer":提交 offer
- POST "/answer":提交 answer
- POST "/candidate":提交 candidate
- 认证与安全
- 所有受保护路由需携带请求头 "session-id"
- 房间与用户信息
- GET "/rooms":获取房间与用户信息(含 sessionId、connected)
```mermaid
flowchart TD
Start(["开始"]) --> CreateSession["PUT '' 创建会话"]
CreateSession --> CreateConn["PUT '/connection' 创建连接"]
CreateConn --> PollLoop["轮询 GET ''/offer/answer/candidate"]
PollLoop --> PostOffer["POST '/offer' 提交 offer"]
PollLoop --> PostAnswer["POST '/answer' 提交 answer"]
PollLoop --> PostCandidate["POST '/candidate' 提交 candidate"]
PostOffer --> PollLoop
PostAnswer --> PollLoop
PostCandidate --> PollLoop
PollLoop --> DeleteConn["DELETE '/connection' 删除连接"]
DeleteConn --> DeleteSession["DELETE '' 删除会话"]
DeleteSession --> End(["结束"])
```
图表来源
- [src/signaling.ts:6-24](file://src/signaling.ts#L6-L24)
- [src/class/httphandler.ts:664-696](file://src/class/httphandler.ts#L664-L696)
- [src/class/httphandler.ts:698-828](file://src/class/httphandler.ts#L698-L828)
- [src/class/httphandler.ts:830-998](file://src/class/httphandler.ts#L830-L998)
- [src/class/httphandler.ts:1041-1076](file://src/class/httphandler.ts#L1041-L1076)
章节来源
- [src/signaling.ts:1-25](file://src/signaling.ts#L1-L25)
- [src/class/httphandler.ts:1-1130](file://src/class/httphandler.ts#L1-L1130)
### 信令消息数据结构
- Offer
- 字段:sdp、datetime、polite
- 场景:发起端创建本地 offer 并通过信令通道发送给对端
- Answer
- 字段:sdp、datetime
- 场景:应答端收到 offer 后创建 answer 并回传
- Candidate
- 字段:candidate、sdpMLineIndex、sdpMid、datetime
- 场景:ICE 候选者收集阶段持续发送,帮助建立 P2P 连接
```mermaid
classDiagram
class Offer {
+string sdp
+number datetime
+boolean polite
}
class Answer {
+string sdp
+number datetime
}
class Candidate {
+string candidate
+number sdpMLineIndex
+string sdpMid
+number datetime
}
```
图表来源
- [src/class/offer.ts:1-11](file://src/class/offer.ts#L1-L11)
- [src/class/answer.ts:1-8](file://src/class/answer.ts#L1-L8)
- [src/class/candidate.ts:1-12](file://src/class/candidate.ts#L1-L12)
章节来源
- [src/class/offer.ts:1-11](file://src/class/offer.ts#L1-L11)
- [src/class/answer.ts:1-8](file://src/class/answer.ts#L1-L8)
- [src/class/candidate.ts:1-12](file://src/class/candidate.ts#L1-L12)
### Swagger 自动生成的 API 文档
- 生成与访问
- 初始化 Swagger,自动扫描 /src/class/httphandler.ts 与 /src/signaling.ts 中的注释
- 访问地址:/api-docs(根据运行协议与端口动态生成)
- 安全方案
- sessionAuth:通过请求头 "session-id" 进行认证
章节来源
- [src/swagger.ts:16-65](file://src/swagger.ts#L16-L65)
### API 使用示例与集成模板
- 客户端封装
- HTTP 信令封装:Signaling 类,提供 start/stop、createConnection/deleteConnection、sendOffer/sendAnswer/sendCandidate、getAll 等方法
- WebSocket 信令封装:WebSocketSignaling 类,提供 createConnection/sendOffer/sendAnswer/sendCandidate/sendMessage 等方法
- Peer 连接控制:Peer 类,封装 RTCPeerConnection、ICE 候选者、状态变化等
- 示例流程
- HTTP 模式:创建会话 → 创建连接 → 轮询获取信令 → 发送 offer/answer/candidate → 删除连接/会话
- WebSocket 模式:建立连接 → 发送 connect → 发送 offer/answer/candidate → 接收对端信令 → 断开连接
章节来源
- [client/src/signaling.js:1-292](file://client/src/signaling.js#L1-L292)
- [client/src/peer.js:1-188](file://client/src/peer.js#L1-L188)
## 依赖关系分析
- 服务端依赖
- Express、ws、swagger-jsdoc、swagger-ui-express、uuid、cors、morgan、multer
- 关键依赖链
- src/index.ts → src/server.ts → src/signaling.ts → src/class/httphandler.ts
- src/index.ts → src/websocket.ts → src/class/websockethandler.ts
- src/swagger.ts → src/class/httphandler.ts 与 src/signaling.ts
```mermaid
graph LR
pkg["package.json 依赖声明"] --> exp["express"]
pkg --> wsdep["ws"]
pkg --> swagger["swagger-jsdoc / swagger-ui-express"]
pkg --> uuiddep["uuid"]
pkg --> corsdep["cors"]
pkg --> morgandep["morgan"]
pkg --> multerdep["multer"]
idx["src/index.ts"] --> srv["src/server.ts"]
idx --> wsc["src/websocket.ts"]
srv --> sig["src/signaling.ts"]
sig --> hth["src/class/httphandler.ts"]
wsc --> wsh["src/class/websockethandler.ts"]
srv --> swg["src/swagger.ts"]
swg --> hth
swg --> sig
```
图表来源
- [package.json:14-46](file://package.json#L14-L46)
- [src/index.ts:13-109](file://src/index.ts#L13-L109)
- [src/server.ts:14-89](file://src/server.ts#L14-L89)
- [src/websocket.ts:6-118](file://src/websocket.ts#L6-L118)
- [src/signaling.ts:1-25](file://src/signaling.ts#L1-L25)
- [src/class/httphandler.ts:1-1130](file://src/class/httphandler.ts#L1-L1130)
- [src/class/websockethandler.ts:1-479](file://src/class/websockethandler.ts#L1-L479)
- [src/swagger.ts:16-65](file://src/swagger.ts#L16-L65)
章节来源
- [package.json:14-46](file://package.json#L14-L46)
- [src/index.ts:13-109](file://src/index.ts#L13-L109)
## 性能考量
- WebSocket
- 低延迟、高吞吐,适合高频信令与实时交互
- 心跳检测与超时断开避免僵尸连接占用资源
- HTTP 轮询
- 增量查询 fromtime 参数减少无效传输
- 会话超时清理机制降低内存占用
- 服务器配置
- 日志级别可调,生产环境建议调整以减少 I/O 开销
- HTTPS 证书启用时建议使用强密码套件与现代 TLS 版本
## 故障排查指南
- 常见错误与处理
- 404 会话不存在:检查 session-id 是否正确传递
- 400 参数缺失:确保请求体包含 connectionId
- 400 连接 ID 已被使用(私有模式):更换唯一 connectionId
- 会话超时:定期轮询或保持 WebSocket 连接活跃
- 测试参考
- WebSocket 单测验证公共/私有模式下的消息转发与断开行为
- HTTP 单测验证会话创建/删除、连接管理、信令存取与超时清理
章节来源
- [test/websockethandler.test.ts:1-191](file://test/websockethandler.test.ts#L1-L191)
- [test/httphandler.test.ts:1-510](file://test/httphandler.test.ts#L1-L510)
## 结论
本项目提供了完整的 WebRTC 信令解决方案,支持 WebSocket 与 HTTP 轮询两种模式,满足不同部署与网络环境需求。通过清晰的 API 规范、完善的 Swagger 文档与客户端封装,开发者可快速集成并稳定运行信令服务。
## 附录
- 端点一览(HTTP 轮询)
- GET /signaling/connection-ids:获取所有活跃连接 ID
- GET /signaling/connection:获取连接列表
- GET /signaling/offer:获取 offer 列表(可选 fromtime)
- GET /signaling/answer:获取 answer 列表(可选 fromtime)
- GET /signaling/candidate:获取 candidate 列表(可选 fromtime)
- GET /signaling:获取所有信令(可选 fromtime)
- PUT /signaling:创建会话(返回 sessionId)
- DELETE /signaling:删除会话
- PUT /signaling/connection:创建连接
- DELETE /signaling/connection:删除连接
- POST /signaling/offer:提交 offer
- POST /signaling/answer:提交 answer
- POST /signaling/candidate:提交 candidate
- GET /signaling/rooms:获取房间与用户信息
- 客户端集成要点
- HTTP 模式:使用 Signaling 类管理会话与轮询
- WebSocket 模式:使用 WebSocketSignaling 类进行实时信令
- Peer 控制:使用 Peer 类处理 RTCPeerConnection 生命周期与 ICE 候选者