申請流程
要使用 API,需要先到 Sora Videos Generation API 對應頁面申請對應的服務,進入頁面之後,點擊「Acquire」按鈕,如圖所示:
如果你尚未登錄或註冊,會自動跳轉到登錄頁面邀請您來註冊和登錄,登錄註冊之後會自動返回當前頁面。
在首次申請時會有免費額度贈送,可以免費使用該 API。
基本使用
首先先了解下基本的使用方式,就是輸入提示詞prompt、參考圖片鏈接數組 image_urls 以及模型 model,便可獲得處理後的結果,具體的內容如下:

accept:想要接收怎樣格式的響應結果,這裡填寫為application/json,即 JSON 格式。authorization:調用 API 的密鑰,申請之後可以直接下拉選擇。
model:生成視頻的模型,主要有sora-2、sora-2-pro,目前sora-2、sora-2-pro可以自主選擇size、duration參數的視頻,其中sora-2-pro可以支持duration為25s的視頻,而sora-2只支持10、15秒的視頻。size:此次視頻生成任務的清晰度,分別有small、large。image_urls:需要上傳的參考圖片鏈接或者Base64編碼數組。duration:此次視頻生成任務的時長,分別有10s、15s、25s,目前只有sora-2-pro支持25s。character_start/character_end:角色在畫面中的起止位置(0-1),用於控制主體位置。orientation:畫幅方向,支持landscape、portrait、square。prompt:提示詞。callback_url:需要回調結果的URL。

success,此時視頻生成任務的狀態情況。task_id,此時視頻生成任務ID。trace_id,此時視頻生成跟蹤ID。data,此時視頻生成任務的結果列表。id,此時視頻生成任務的視頻ID。video_url,此時視頻生成任務的視頻鏈接。state,此時視頻生成任務的狀態。
data 的視頻鏈接地址獲取生成的Sora視頻即可。
另外如果想生成對應的對接代碼,可以直接複製生成,例如 CURL 的代碼如下:
圖生視頻任務
如果想圖生視頻任務, 首先參數image_urls必須傳入參考圖片鏈接,就可以指定如下內容:
- image_urls:該圖生視頻任務采用的參考圖鏈接數組。


角色生成視頻任務
如果想角色生成視頻任務, 首先參數character_url必須傳入創建角色需要的視頻鏈接,注意視頻中一定不能出現真人,否則會失敗,就可以指定如下內容:
- character_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:錯誤請求,可能是由於缺少或無效的參數。400 api_not_implemented:錯誤請求,可能是由於缺少或無效的參數。401 invalid_token:未授權,無效或缺少授權令牌。429 too_many_requests:請求過多,您已超過速率限制。500 api_error:內部伺服器錯誤,伺服器出現問題。

