申请流程
要使用 API,需要先到 Midjourney Videos API 对应页面申请对应的服务,进入页面之后,点击「Acquire」按钮,如图所示:
如果你尚未登录或注册,会自动跳转到登录页面邀请您来注册和登录,登录注册之后会自动返回当前页面。
在首次申请时会有免费额度赠送,可以免费使用该 API。
基本使用
首先先了解下基本的使用方式,就是输入提示词prompt、 生成行为 action、首尾帧参考图片数组 image_url,便可获得处理后的结果,首先需要简单地传递一个 action 字段,它的值为 generate,它主要包含二种行为:生成视频(generate)、扩展视频(extend),具体的内容如下:

accept:想要接收怎样格式的响应结果,这里填写为application/json,即 JSON 格式。authorization:调用 API 的密钥,申请之后可以直接下拉选择。
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。

success,此时视频生成任务的状态情况。task_id,此时视频生成任务ID。image_url,此时视频生成任务的封面图片。image_width,此时视频生成任务的封面图片宽度。image_height,此时视频生成任务的封面图片高度。video_id,此时视频生成任务的视频ID。video_urls,此时视频生成任务的视频链接数组。
video_urls 的视频链接地址获取生成的Midjourney视频即可。
另外如果想生成对应的对接代码,可以直接复制生成,例如 CURL 的代码如下:
扩展视频功能
如果想对已经生成的Kling视频进行继续生成的话,可以将参数action 设置为 extend ,并且输入需要继续生成视频的 ID,视频 ID 的获取是根据基本使用来获取。
这时候可以看到上文视频的 ID 为:
注意,这里的视频中 video_id 是生成后视频的 ID,如果你不知道如何生成视频,可以参考上文的基本使用来生成视频。
接下来我们要必须填下一步需要扩展的提示词来自定义生成视频,就可以指定如下内容:
video_index:选定扩展的视频索引,该索引是上文生成的video_urls,该索引从0开始,默认值是0。video_id:扩展视频所指定的视频ID。action:此次扩展视频的行为,为extend。prompt:提示词。


异步回调
由于 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,如图所示:

https://webhook.site/556e6971-b41f-4fa8-9151-6e91acd0399f。
接下来,我们可以设置字段 callback_url 为上述 Webhook URL,同时填入相应的参数,具体的内容如图所示:

https://webhook.site/556e6971-b41f-4fa8-9151-6e91acd0399f 上观察到生成视频的结果,如图所示:

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.

