- Version 1(经典模式):支持
duration(10/15/25 秒)、orientation(横屏/竖屏)、size(small/large 清晰度)、参考图image_urls、角色视频character_url等参数。 - Version 2(合作商模式):支持
seconds(4/8/12 秒)、像素级分辨率size(如 1280x720)、参考图input_reference等参数。
申请流程
要使用 API,需要先到 Sora Videos Generation API 对应页面申请对应的服务,进入页面之后,点击「Acquire」按钮,如图所示:
如果你尚未登录或注册,会自动跳转到登录页面邀请您来注册和登录,登录注册之后会自动返回当前页面。
在首次申请时会有免费额度赠送,可以免费使用该 API。
基本使用(Version 1)
首先先了解 Version 1 的基本使用方式,就是输入提示词prompt、参考图片链接数组 image_urls 以及模型 model,便可获得处理后的结果,具体的内容如下:

accept:想要接收怎样格式的响应结果,这里填写为application/json,即 JSON 格式。authorization:调用 API 的密钥,申请之后可以直接下拉选择。
model:生成视频的模型,支持sora-2(标准模式)和sora-2-pro(高清模式)。其中sora-2-pro可以支持duration为 25 秒的视频,而sora-2只支持 10、15 秒。size:视频清晰度,small为标准清晰度、large为 HD 清晰度(仅 Version 1)。duration:视频时长,支持 10、15、25 秒,其中 25 秒仅sora-2-pro支持(仅 Version 1)。orientation:画幅方向,支持landscape(横屏)、portrait(竖屏)(仅 Version 1)。image_urls:参考图片链接数组,用于图生视频(仅 Version 1)。character_url:角色视频链接,视频中不能出现真人(仅 Version 1)。character_start/character_end:角色出现的起止秒数,范围差值为 1-3 秒(仅 Version 1)。prompt:提示词(必填)。callback_url:异步回调结果的 URL。version:API 版本,"1.0"(默认)或"2.0"。

success,此时视频生成任务的状态情况。task_id,此时视频生成任务ID。trace_id,此时视频生成跟踪ID。data,此时视频生成任务的结果列表。id,此时视频生成任务的视频ID。video_url,此时视频生成任务的视频链接。state,此时视频生成任务的状态。
data 的视频链接地址获取生成的Sora视频即可。
另外如果想生成对应的对接代码,可以直接复制生成,例如 CURL 的代码如下:
图生视频任务(Version 1)
如果想进行图生视频任务,首先参数image_urls 必须传入参考图片链接,就可以指定如下内容:
image_urls:该图生视频任务采用的参考图链接数组。注意不可传递真实的带有头像的人物图像,否则可能导致任务失败。


角色生成视频任务(Version 1)
如果想进行角色生成视频任务,首先参数character_url 必须传入创建角色需要的视频链接,注意视频中一定不能出现真人,否则会失败,就可以指定如下内容:
- character_url:创建角色需要的视频链接,注意视频中一定不能出现真人,否则会失败。


Version 2.0 模式
除了上述 Version 1.0 模式之外,本 API 还支持 Version 2.0 模式,通过设置version 参数为 "2.0" 即可启用。Version 2.0 模式支持更短的视频时长和像素级的分辨率控制。
Version 2.0 参数说明
| 参数 | 类型 | 是否必填 | 说明 |
|---|---|---|---|
version | string | 是 | 设置为 "2.0" |
prompt | string | 是 | 生成视频的提示词 |
model | string | 否 | sora-2(默认)或 sora-2-pro |
duration | integer | 否 | 视频时长:4(默认)、8、12 秒 |
size | string | 否 | 分辨率:720x1280(默认)、1280x720、1024x1792、1792x1024 |
image_urls | array | 否 | 参考图片 URL 数组,仅使用第一张图片,图片尺寸需要与 size 参数一致 |
callback_url | string | 否 | 异步回调 URL |
基本示例
使用参考图片(Version 2.0)
在 Version 2.0 模式下,可以通过image_urls 参数传入参考图片来引导视频生成(仅使用第一张图片):
注意:参考图片的尺寸应与size参数保持一致,例如size为1280x720时,参考图片尺寸应为 1280×720。
Version 1.0 与 Version 2.0 参数对比
| 参数 | Version 1.0 | Version 2.0 |
|---|---|---|
version | 1.0(默认) | 2.0 |
prompt | ✅ | ✅ |
model | ✅ sora-2 / sora-2-pro | ✅ sora-2 / sora-2-pro |
duration | ✅ 10/15/25 秒 | ✅ 4/8/12 秒 |
orientation | ✅ landscape/portrait | ❌ |
size | ✅ small/large | ✅ 720x1280/1280x720/1024x1792/1792x1024 |
image_urls | ✅ 多张参考图 | ✅ 仅使用第一张 |
character_url | ✅ | ❌ |
callback_url | ✅ | ✅ |
异步回调
由于 Sora Videos Generation API生成的时间相对较长,大约需要 1-2 分钟,如果 API 长时间无响应,HTTP 请求会一直保持连接,导致额外的系统资源消耗,所以本 API 也提供了异步回调的支持。 整体流程是:客户端发起请求的时候,额外指定一个callback_url 字段,客户端发起 API 请求之后,API 会立马返回一个结果,包含一个 task_id 的字段信息,代表当前的任务 ID。当任务完成之后,生成视频的结果会通过 POST JSON 的形式发送到客户端指定的 callback_url,其中也包括了 task_id 字段,这样任务结果就可以通过 ID 关联起来了。
下面我们通过示例来了解下具体怎样操作。
首先,Webhook 回调是一个可以接收 HTTP 请求的服务,开发者应该替换为自己搭建的 HTTP 服务器的 URL。此处为了方便演示,使用一个公开的 Webhook 样例网站 https://webhook.site/,打开该网站即可得到一个 Webhook URL,如图所示:
将此 URL 复制下来,就可以作为 Webhook 来使用,此处的样例为 https://webhook.site/eb238c4f-da3b-47a5-a922-a93aa5405daa。
接下来,我们可以设置字段 callback_url 为上述 Webhook URL,同时填入相应的参数,具体的内容如图所示:

https://webhook.site/eb238c4f-da3b-47a5-a922-a93aa5405daa 上观察到生成视频的结果,如图所示:
内容如下:
task_id 字段,其他的字段都和上文类似,通过该字段即可实现任务的关联。
错误处理
在调用 API 时,如果遇到错误,API 会返回相应的错误代码和信息。例如:400 token_mismatched:Bad request, possibly due to missing or invalid parameters.400 api_not_implemented:Bad request, possibly due to missing or invalid parameters.401 invalid_token:Unauthorized, invalid or missing authorization token.429 too_many_requests:Too many requests, you have exceeded the rate limit.500 api_error:Internal server error, something went wrong on the server.

