- 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,可能因為缺少或無效參數。400 api_not_implemented:Bad request,可能因為缺少或無效參數。401 invalid_token:Unauthorized,無效或缺少授權令牌。429 too_many_requests:請求過多,您已超過速率限制。500 api_error:內部伺服器錯誤,伺服器發生異常。

