当从分离音频生成 MIDI 完成时,系统将调用此回调。当您向 Suno API 提交 MIDI 生成任务时,可以使用 callBackUrl 参数设置回调 URL。系统将在任务完成时自动将结果推送到您指定的地址。回调机制概述#
回调机制无需轮询 API 查询任务状态。系统将主动向您的服务器推送任务完成结果。
Webhook 安全性:为确保回调请求的真实性和完整性,我们强烈建议您实现 webhook 签名验证。请参阅我们的 Webhook 校验指南 了解详细实现步骤。 回调时机#
回调方法#
Content Type: application/json
回调请求格式#
当任务完成时,系统将向您的 callBackUrl 发送 POST 请求:{
"task_id": "5c79****be8e",
"code": 200,
"msg": "success",
"data": {
"state": "complete",
"instruments": [
{
"name": "Drums",
"notes": [
{
"pitch": 73,
"start": "0.036458333333333336",
"end": "0.18229166666666666",
"velocity": 1
},
{
"pitch": 61,
"start": 0.046875,
"end": "0.19270833333333334",
"velocity": 1
}
]
}
]
}
}
状态码说明#
code (integer, required)#
| 状态码 | 说明 |
|---|
| 200 | 成功 - MIDI 生成已成功完成 |
| 500 | 内部错误 - 请重试或联系技术支持 |
msg (string, required)#
task_id (string, required)#
任务 ID,与您提交任务时返回的 task_id 一致data (object)#
成功响应字段#
data.state (string)#
data.instruments (array)#
乐器对象属性
name (string): 乐器名称(例如:"Drums"、"Electric Bass (finger)"、"Acoustic Grand Piano")
notes (array): 该乐器的 MIDI 音符数组
音符对象属性
pitch (integer): MIDI 音符编号(0-127)。中央 C = 60。MIDI 音符参考 start (number | string): 音符起始时间,从音频开头算起的秒数
end (number | string): 音符结束时间,从音频开头算起的秒数
velocity (number): 音符力度/强度(0-1 范围)。1 = 最大力度
回调接收示例#
最佳实践#
回调 URL 配置建议#
1.
使用 HTTPS: 确保回调 URL 使用 HTTPS 协议以保证数据传输安全
3.
幂等处理: 同一 task_id 可能收到多次回调,确保处理逻辑是幂等的
4.
快速响应: 回调处理应快速返回 200 状态码以避免超时
5.
异步处理: 复杂的业务逻辑(如 MIDI 文件转换)应异步处理
6.
处理缺失乐器: 不是所有乐器都会被检测到 - 优雅地处理空的或缺失的乐器数组
7.
存储原始数据: 保存完整的 JSON 响应以供未来参考和重新处理
重要提醒#
请确保回调处理逻辑的稳定性,避免因异常导致回调失败
MIDI 数据保留 14 天 - 如需长期保存请及时下载保存
音符时间(start/end)可能是字符串 or 数字 - 需要处理这两种类型
故障排查#
网络连接问题
服务器响应问题
确保服务器在 15 秒内返回 HTTP 200 状态码
内容格式问题
检查 Content-Type 是否为 application/json
数据处理问题
验证原始人声分离使用的是 split_stem 类型(而非 separate_vocal)
替代方案#
轮询查询结果
使用获取 MIDI 生成详情接口定期查询任务状态。我们建议每 10-30 秒查询一次。