本文将介绍一种 Kling Videos Generation API 对接说明,它是可以通过输入自定义参数来生成Kling官方的视频。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.
申请流程
要使用 API,需要先到 Kling Videos Generation API 对应页面申请对应的服务,进入页面之后,点击「Acquire」按钮,如图所示:
如果你尚未登录或注册,会自动跳转到登录页面邀请您来注册和登录,登录注册之后会自动返回当前页面。
在首次申请时会有免费额度赠送,可以免费使用该 API。
基本使用
首先先了解下基本的使用方式,就是输入提示词prompt、 生成行为 action、首帧参考图片 start_image_url 以及模型 model,便可获得处理后的结果,首先需要简单地传递一个 action 字段,它的值为 text2video,它主要包含三种行为:文生视频(text2video)、图生视频(image2video)、扩展视频(extend),然后我们还需要输入模型 model,目前主要有 kling-v1, kling-v1-6, kling-v2-master, kling-v2-1-master, kling-v2-5-turbo, kling-v2-6, kling-v3, kling-v3-omni, kling-video-o1 模型,具体的内容如下:

accept:想要接收怎样格式的响应结果,这里填写为application/json,即 JSON 格式。authorization:调用 API 的密钥,申请之后可以直接下拉选择。
model:生成视频的模型,主要有kling-v1,kling-v1-6,kling-v2-master,kling-v2-1-master,kling-v2-5-turbo,kling-v2-6,kling-v3,kling-v3-omni,kling-video-o1模型。mode:生成视频的模式,可选值为标准模式std、极速模式pro和原生 4K 模式4k。其中4k仅支持kling-v3和kling-v3-omni,且与camera_control(运镜控制)不兼容。action:此次视频生成任务的行为,主要包含三种行为,分别为:文生视频(text2video)、图生视频(image2video)、扩展视频(extend)。start_image_url:当选择图生视频行为image2video就必须需要上传的首帧参考图片链接。end_image_url:图生视频时可选,指定尾帧。duration:视频时长,单位秒。对于kling-v3和kling-v3-omni模型支持灵活时长 3-15 秒(整数),其他模型支持 5 或 10 秒。generate_audio:是否同步生成音频,可选,布尔值。支持kling-v3、kling-v3-omni以及kling-v2-6(仅 pro 模式)。默认为false。aspect_ratio:视频宽高比,可选,支持16:9、9:16、1:1,默认16:9。cfg_scale:相关性强度,范围 [0,1],越大越贴合提示词。camera_control:可选,控制相机运动的对象参数,支持 type/simple 预设以及 horizontal、vertical、pan、tilt、roll、zoom 等配置。negative_prompt:可选,不希望出现的反向提示词,最多 200 字符。element_list:主体参考列表,只适用模型kling-video-o1,该参数的具体的使用方式参考官网文档。video_list:参考视频,通过URL方式获取,只适用模型kling-video-o1,该参数的具体的使用方式参考官网文档。prompt:提示词。callback_url:需要回调结果的URL。

success,此时视频生成任务的状态情况。task_id,此时视频生成任务ID。video_id,此时视频生成任务的视频ID。video_url,此时视频生成任务的视频链接。duration,此时视频生成任务的视频链时长。state,此时视频生成任务的状态。
data 的视频链接地址获取生成的Kling视频即可。
另外如果想生成对应的对接代码,可以直接复制生成,例如 CURL 的代码如下:
模型能力矩阵
不同模型对参数的支持情况差异较大。以下矩阵整理自 Kling 官方 video models 文档,调用前请先核对当前model / mode / duration 组合是否支持你所需的功能,否则上游会返回 model/mode/duration(...) is not supported with image_tail 等错误。
| 模型 | 模式 | end_image_url(首尾帧) | generate_audio(伴音) | camera_control(运镜) | 备注 |
|---|---|---|---|---|---|
kling-v1 | std / pro | ✅ 仅 duration=5 | ❌ | ✅ 仅 duration=5 | extend 不支持 negative_prompt 与 cfg_scale |
kling-v1-6 | std | ❌ | ❌ | ❌ | 多图生视频、extend 全模式可用 |
kling-v1-6 | pro | ✅ | ❌ | ❌ | |
kling-v2-master | — | ❌ | ❌ | ❌ | 单一模式,仅 duration=5/10 |
kling-v2-1-master | — | ❌ | ❌ | ❌ | 单一模式,仅 duration=5/10 |
kling-v2-5-turbo | std | ❌ | ❌ | ❌ | |
kling-v2-5-turbo | pro | ✅ | ❌ | ❌ | |
kling-v2-6 | std | ❌ | ❌ | ❌ | |
kling-v2-6 | pro | ✅ | ✅ | ❌ | 唯一同时支持伴音的非 v3 模型 |
kling-v3 | std / pro | ✅ | ✅ | ✅ | duration 范围 3–15 秒 |
kling-v3 | 4k | ✅ | ✅ | ❌ | 4K 模式与运镜不兼容 |
kling-v3-omni | std / pro / 4k | ✅ | ✅ | ❌ | |
kling-video-o1 | std / pro | ✅ | ❌ | ❌ | 仅支持 duration=5/10 |
mode=4k仅kling-v3与kling-v3-omni支持;并且与camera_control(运镜)互斥。end_image_url只能在action=image2video时配合start_image_url使用。仅传end_image_url(无start_image_url)会被拒绝。kling-v3/kling-v3-omni接受任意 3–15 秒的整数duration;其余模型只接受 5 或 10。generate_audio默认false。仅kling-v3、kling-v3-omni和kling-v2-6(pro 模式)支持。
扩展视频功能
如果想对已经生成的Kling视频进行继续生成的话,可以将参数action 设置为 extend ,并且输入需要继续生成视频的 ID,视频 ID 的获取是根据基本使用来获取,如下图所示:

注意,这里的视频中 video_id 是生成后视频的 ID,如果你不知道如何生成视频,可以参考上文的基本使用来生成视频。
接下来我们要必须填下一步需要扩展的提示词来自定义生成视频,就可以指定如下内容:
model:生成视频的模型,主要有kling-v1、kling-v1-5和kling-v1-6模型。mode:生成视频的模式,可选值为标准模式std、极速模式pro和原生 4K 模式4k(仅kling-v3和kling-v3-omni支持,与运镜控制不兼容)。duration:此次视频生成任务的视频时长,主要包含5s和10s。start_image_url:当选择图生视频行为image2video就必须需要上传的首帧参考图片链接。prompt:提示词。


异步回调
由于 Kling 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/624b2c78-6dbd-4618-9d2b-b32eade6d8c3。
接下来,我们可以设置字段 callback_url 为上述 Webhook URL,同时填入相应的参数,具体的内容如图所示:

https://webhook.site/624b2c78-6dbd-4618-9d2b-b32eade6d8c3 上观察到生成视频的结果,如图所示:
内容如下:
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.

