Documentation Index
Fetch the complete documentation index at: https://docs.xhuoapi.ai/llms.txt
Use this file to discover all available pages before exploring further.
本文將介紹一種 Midjourney Videos API 對接說明,它是可以透過輸入自定義參數來生成Midjourney官方的視頻。
申請流程
要使用 API,需要先到 Midjourney Videos API 對應頁面申請對應的服務,進入頁面之後,點擊「Acquire」按鈕,如圖所示:
如果你尚未登入或註冊,會自動跳轉到登入頁面邀請您來註冊和登入,登入註冊之後會自動返回當前頁面。
在首次申請時會有免費額度贈送,可以免費使用該 API。
基本使用
首先先了解下基本的使用方式,就是輸入提示詞 prompt、 生成行為 action、首尾幀參考圖片數組 image_url,便可獲得處理後的結果,首先需要簡單地傳遞一個 action 欄位,它的值為 generate,它主要包含二種行為:生成視頻(generate)、擴展視頻(extend),具體的內容如下:

可以看到這裡我們設置了 Request Headers,包括:
accept:想要接收怎樣格式的響應結果,這裡填寫為 application/json,即 JSON 格式。
authorization:調用 API 的密鑰,申請之後可以直接下拉選擇。
另外設置了 Request Body,包括:
image_url:生成視頻的的首幀參考圖片鏈接。
end_image_url:可選,指定生成視頻的尾幀參考圖。
video_id:擴展視頻時需要指定視頻ID。
video_index:擴展視頻時需要指定video_id指定的具體哪個視頻,索引從0開始,默認是0。
action:此次視頻生成任務的行為,主要包含二種行為,分別為:生成視頻(generate)、擴展視頻(extend)。
prompt:提示詞。
mode:視頻生成速度模式,默認 fast。
resolution:視頻清晰度,默認 720p。
loop:是否生成循環視頻,默認 false。
callback_url:需要回調結果的URL。
選擇之後,可以發現右側也生成了對應代碼,如圖所示:

點擊「Try」按鈕即可進行測試,如上圖所示,這裡我們就得到了如下結果:
{
"image_url": "https://storage.fonedis.cc/upload_1751816808164156352.png",
"image_width": 560,
"image_height": 688,
"progress": 100,
"video_id": "1751816807896311",
"video_urls": [
"https://storage.fonedis.cc//video/1c67c36c-8177-4f19-ad72-1dc1567265a6/0_0.mp4",
"https://storage.fonedis.cc//video/1c67c36c-8177-4f19-ad72-1dc1567265a6/0_1.mp4",
"https://storage.fonedis.cc//video/1c67c36c-8177-4f19-ad72-1dc1567265a6/0_2.mp4",
"https://storage.fonedis.cc//video/1c67c36c-8177-4f19-ad72-1dc1567265a6/0_3.mp4"
],
"task_id": "037955e0-deee-4050-baa8-1416300d67e2",
"success": true
}
返回結果一共有多個欄位,介紹如下:
success,此時視頻生成任務的狀態情況。
task_id,此時視頻生成任務ID。
image_url,此時視頻生成任務的封面圖片。
image_width,此時視頻生成任務的封面圖片寬度。
image_height,此時視頻生成任務的封面圖片高度。
video_id,此時視頻生成任務的視頻ID。
video_urls,此時視頻生成任務的視頻鏈接數組。
可以看到我們得到了滿意的視頻信息,我們只需要根據結果中 video_urls 的視頻鏈接地址獲取生成的Midjourney視頻即可。
另外如果想生成對應的對接代碼,可以直接複製生成,例如 CURL 的代碼如下:
curl -X POST 'https://api.xhuoapi.ai/v1/midjourney/videos' \
-H 'accept: application/json' \
-H 'authorization: Bearer {token}' \
-H 'content-type: application/json' \
-d '{
"action": "generate",
"prompt": "A cat sitting on a table",
"image_url": "https://cdn.xhuoapi.ai/jgo1cw.jpg"
}'
擴展視頻功能
如果想對已經生成的Kling視頻進行繼續生成的話,可以將參數 action 設置為 extend ,並且輸入需要繼續生成視頻的 ID,視頻 ID 的獲取是根據基本使用來獲取。
這時可以看到上文視頻的 ID 為:
"video_id": "1751816807896311"
注意,這裡的視頻中 video_id 是生成後視頻的 ID,如果你不知道如何生成視頻,可以參考上文的基本使用來生成視頻。
接下來我們要必須填下一步需要擴展的提示詞來自定義生成視頻,就可以指定如下內容:
video_index:選定擴展的視頻索引,該索引是上文生成的video_urls ,該索引從0開始,默認值是0。
video_id:擴展視頻所指定的視頻ID。
action:此次擴展視頻的行為,為extend。
prompt:提示詞。
填寫樣例如下:

填寫完畢之後自動生成了代碼如下:

對應的 Python 代碼:
import requests
url = "https://api.xhuoapi.ai/v1/midjourney/videos"
headers = {
"accept": "application/json",
"authorization": "Bearer {token}",
"content-type": "application/json"
}
payload = {
"action": "extend",
"prompt": "A cat sitting on a table",
"video_id": "1751816807896311",
"video_index": 1
}
response = requests.post(url, json=payload, headers=headers)
print(response.text)
點擊運行,可以發現會得到一個結果,如下:
{
"image_url": "https://storage.fonedis.cc/upload_1751817471047011172.png",
"image_width": 560,
"image_height": 688,
"progress": 100,
"video_id": "1751818094559027",
"video_urls": [
"https://storage.fonedis.cc//video/a4bd2f43-b925-462d-9725-8aef98403133/0_0.mp4",
"https://storage.fonedis.cc//video/a4bd2f43-b925-462d-9725-8aef98403133/0_1.mp4",
"https://storage.fonedis.cc//video/a4bd2f43-b925-462d-9725-8aef98403133/0_2.mp4",
"https://storage.fonedis.cc//video/a4bd2f43-b925-462d-9725-8aef98403133/0_3.mp4"
],
"task_id": "da3bdcd0-9c21-4b40-877a-2c36e5f479e5",
"success": true
}
可以看出,結果內容與上文的是一致的,這也就實現視頻的擴展視頻功能。
異步回調
由於 Midjourney Videos 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/556e6971-b41f-4fa8-9151-6e91acd0399f。
接下來,我們可以設置字段 callback_url 為上述 Webhook URL,同時填入相應的參數,具體的內容如圖所示:

點擊運行,可以發現會立即得到一個結果,如下:
{
"task_id": "b726a27a-f379-4d91-b569-cfe4b7b299ee"
}
稍等片刻,我們可以在 https://webhook.site/556e6971-b41f-4fa8-9151-6e91acd0399f 上觀察到生成視頻的結果,如圖所示:

內容如下:
{
"image_url": "https://storage.fonedis.cc/upload_1751818513244368774.png",
"image_width": 560,
"image_height": 688,
"progress": 100,
"video_id": "1751818512924054",
"video_urls": [
"https://storage.fonedis.cc//video/9ff3783e-bcf6-4f11-b738-09aa52318e6e/0_0.mp4",
"https://storage.fonedis.cc//video/9ff3783e-bcf6-4f11-b738-09aa52318e6e/0_1.mp4",
"https://storage.fonedis.cc//video/9ff3783e-bcf6-4f11-b738-09aa52318e6e/0_2.mp4",
"https://storage.fonedis.cc//video/9ff3783e-bcf6-4f11-b738-09aa52318e6e/0_3.mp4"
],
"task_id": "b726a27a-f379-4d91-b569-cfe4b7b299ee",
"success": true
}
可以看到結果中有一個 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.
錯誤響應示例
{
"success": false,
"error": {
"code": "api_error",
"message": "fetch failed"
},
"trace_id": "2cf86e86-22a4-46e1-ac2f-032c0f2a4e89"
}
通過本文檔,您已經了解了如何使用 Midjourney Videos API 可通過輸入提示詞以及首幀參考圖片來生成視頻。希望本文檔能幫助您更好地對接和使用該 API。如有任何問題,請隨時聯繫我們的技術支持團隊。