Vidu-文生视频模型基于文本提示词,生成一段流畅的视频。
本文档仅适用于“中国内地(北京)”地域,且必须使用该地域的API Key。
服务开通
请前往阿里云百炼控制台,搜索 Vidu,找到 Vidu 模型卡片,单击立即开通;在弹窗内确认开通及授权。
适用范围
为确保调用成功,请务必保证模型、Endpoint URL 和 API Key 均属于同一地域。跨地域调用将会失败。
选择模型:确认模型所属的地域。
选择 URL:选择对应的地域 Endpoint URL,支持HTTP URL或 DashScope SDK URL。
配置 API Key:选择地域并获取API Key,再配置API Key到环境变量。
安装 SDK:如需通过SDK进行调用,请安装DashScope SDK。
HTTP调用
由于文生视频任务耗时较长(通常为1-5分钟),API采用异步调用。整个流程包含 "创建任务 -> 轮询获取" 两个核心步骤,具体如下:
步骤1:创建任务获取任务ID
北京地域:POST https://dashscope.aliyuncs.com/api/v1/services/aigc/video-generation/video-synthesis
创建成功后,使用接口返回的
task_id查询结果,task_id 有效期为 24 小时。请勿重复创建任务,轮询获取即可。新手指引请参见Postman。
请求参数 | 文生视频 |
请求头(Headers) | |
Content-Type 请求内容类型。此参数必须设置为 | |
Content-Type 请求内容类型。此参数必须设置为 | |
X-DashScope-Async 异步处理配置参数。HTTP请求只支持异步,必须设置为 重要 缺少此请求头将报错:“current user api does not support synchronous calls”。 | |
请求体(Request Body) | |
model 模型名称。可选模型请参见模型列表。 示例值:vidu/viduq3-turbo_text2video。 | |
input 输入的基本信息,如提示词等。 | |
parameters 视频生成参数,如设置视频分辨率、时长等。 |
响应参数 | 成功响应请保存 task_id,用于查询任务状态与结果。 异常响应创建任务失败,请参见错误信息进行解决。 |
output 任务输出信息。 | |
request_id 请求唯一标识。可用于请求明细溯源和问题排查。 | |
code 请求失败的错误码。请求成功时不会返回此参数,详情请参见错误信息。 | |
message 请求失败的详细信息。请求成功时不会返回此参数,详情请参见错误信息。 |
步骤2:根据任务ID查询结果
北京地域:GET https://dashscope.aliyuncs.com/api/v1/tasks/{task_id}
请求参数 | 查询任务结果将 |
请求头(Headers) | |
Authorization 请求身份认证。接口使用阿里云百炼API-Key进行身份认证。示例值:Bearer sk-xxxx。 | |
URL路径参数(Path parameters) | |
task_id 任务ID。 |
响应参数 | 任务执行成功视频URL仅保留24小时,超时后会被自动清除,请及时保存生成的视频。 任务执行失败若任务执行失败,task_status将置为 FAILED,并提供错误码和信息。请参见错误信息进行解决。 任务查询过期task_id查询有效期为 24 小时,超时后将无法查询,返回以下报错信息。 |
output 任务输出信息。 | |
usage 输出信息统计,只对成功的结果计数。 | |
request_id 请求唯一标识。可用于请求明细溯源和问题排查。 |
DashScope SDK调用
SDK 的参数命名与HTTP接口基本一致,参数结构根据语言特性进行封装。
由于文生视频任务耗时较长(通常为1-5分钟),SDK 在底层封装了 HTTP 异步调用流程,支持同步、异步两种调用方式。
具体耗时受限于排队任务数和服务执行情况,请在获取结果时耐心等待。
Python SDK调用
请确保 DashScope Python SDK 版本不低于 1.25.8,再运行以下代码。
北京地域:dashscope.base_http_api_url = 'https://dashscope.aliyuncs.com/api/v1'
同步调用
请求示例
from http import HTTPStatus
from dashscope import VideoSynthesis
import dashscope
import os
# 以下为北京地域URL
dashscope.base_http_api_url = 'https://dashscope.aliyuncs.com/api/v1'
# 若没有配置环境变量,请用百炼API Key将下行替换为:api_key="sk-xxx"
api_key = os.getenv("DASHSCOPE_API_KEY")
def sample_sync_call_t2v():
# call sync api, will return the result
print('please wait...')
rsp = VideoSynthesis.call(api_key=api_key,
model='vidu/viduq3-turbo_text2video',
prompt='一只小猫在月光下奔跑',
size='960*528',
duration=5,
resolution='540P',
watermark=True)
print(rsp)
if rsp.status_code == HTTPStatus.OK:
print(rsp.output.video_url)
else:
print('Failed, status_code: %s, code: %s, message: %s' %
(rsp.status_code, rsp.code, rsp.message))
if __name__ == '__main__':
sample_sync_call_t2v()响应示例
video_url24小时内有效,请及时下载。{
"status_code": 200,
"request_id": "15bd86e5-28b1-40ad-a427-xxxxxx",
"code": null,
"message": "",
"output": {
"task_id": "a876c6ee-1c63-4d17-b6c0-xxxxxx",
"task_status": "SUCCEEDED",
"video_url": "https://prod-ss-vidu.s3.cn-northwest-1.amazonaws.com.cn/xxx.mp4?xxx",
"submit_time": "2026-03-27 13:35:49.508",
"scheduled_time": "2026-03-27 13:35:49.540",
"end_time": "2026-03-27 13:36:45.848",
"orig_prompt": "一只小猫在月光下奔跑"
},
"usage": {
"video_count": 1,
"video_duration": 0,
"video_ratio": "",
"duration": 5,
"size": "960*528",
"output_video_duration": 5,
"fps": 24,
"audio": false,
"SR": "540"
}
}异步调用
请求示例
from http import HTTPStatus
from dashscope import VideoSynthesis
import dashscope
import os
# 以下为北京地域URL
dashscope.base_http_api_url = 'https://dashscope.aliyuncs.com/api/v1'
# 若没有配置环境变量,请用百炼API Key将下行替换为:api_key="sk-xxx"
api_key = os.getenv("DASHSCOPE_API_KEY")
def sample_async_call_t2v():
# call async api, will return the task information
rsp = VideoSynthesis.async_call(api_key=api_key,
model='vidu/viduq3-turbo_text2video',
prompt='一只小猫在月光下奔跑',
size='960*528',
duration=5,
resolution='540P')
print(rsp)
if rsp.status_code == HTTPStatus.OK:
print("task_id: %s" % rsp.output.task_id)
else:
print('Failed, status_code: %s, code: %s, message: %s' %
(rsp.status_code, rsp.code, rsp.message))
# get the task information include the task status.
status = VideoSynthesis.fetch(task=rsp, api_key=api_key)
if status.status_code == HTTPStatus.OK:
print(status.output.task_status) # check the task status
else:
print('Failed, status_code: %s, code: %s, message: %s' %
(status.status_code, status.code, status.message))
# wait the task complete
rsp = VideoSynthesis.wait(task=rsp, api_key=api_key)
print(rsp)
if rsp.status_code == HTTPStatus.OK:
print(rsp.output.video_url)
else:
print('Failed, status_code: %s, code: %s, message: %s' %
(rsp.status_code, rsp.code, rsp.message))
if __name__ == '__main__':
sample_async_call_t2v()响应示例
1、创建任务的响应示例
{
"status_code": 200,
"request_id": "c86ff7ba-8377-917a-90ed-xxxxxx",
"code": "",
"message": "",
"output": {
"task_id": "721164c6-8619-4a35-a6d9-xxxxxx",
"task_status": "PENDING",
"video_url": ""
},
"usage": null
}2、查询任务结果的响应示例
video_url 24小时内有效,请及时下载。{
"status_code": 200,
"request_id": "15bd86e5-28b1-40ad-a427-xxxxxx",
"code": null,
"message": "",
"output": {
"task_id": "a876c6ee-1c63-4d17-b6c0-xxxxxx",
"task_status": "SUCCEEDED",
"video_url": "https://prod-ss-vidu.s3.cn-northwest-1.amazonaws.com.cn/xxx.mp4?xxx",
"submit_time": "2026-03-27 13:35:49.508",
"scheduled_time": "2026-03-27 13:35:49.540",
"end_time": "2026-03-27 13:36:45.848",
"orig_prompt": "一只小猫在月光下奔跑"
},
"usage": {
"video_count": 1,
"video_duration": 0,
"video_ratio": "",
"duration": 5,
"size": "960*528",
"output_video_duration": 5,
"fps": 24,
"audio": false,
"SR": "540"
}
}Java SDK调用
请确保 DashScope Java SDK 版本不低于 2.22.6,再运行以下代码。
北京地域:Constants.baseHttpApiUrl = "https://dashscope.aliyuncs.com/api/v1";
同步调用
请求示例
// Copyright (c) Alibaba, Inc. and its affiliates.
import com.alibaba.dashscope.aigc.videosynthesis.VideoSynthesis;
import com.alibaba.dashscope.aigc.videosynthesis.VideoSynthesisParam;
import com.alibaba.dashscope.aigc.videosynthesis.VideoSynthesisResult;
import com.alibaba.dashscope.exception.ApiException;
import com.alibaba.dashscope.exception.InputRequiredException;
import com.alibaba.dashscope.exception.NoApiKeyException;
import com.alibaba.dashscope.utils.JsonUtils;
import com.alibaba.dashscope.utils.Constants;
public class Text2Video {
static {
// 以下为北京地域url
Constants.baseHttpApiUrl = "https://dashscope.aliyuncs.com/api/v1";
}
// 若没有配置环境变量,请用百炼API Key将下行替换为:api_key="sk-xxx"
public static String apiKey = System.getenv("DASHSCOPE_API_KEY");
/**
* Create a video compositing task and wait for the task to complete.
*/
public static void text2Video() throws ApiException, NoApiKeyException, InputRequiredException {
VideoSynthesis vs = new VideoSynthesis();
VideoSynthesisParam param =
VideoSynthesisParam.builder()
.apiKey(apiKey)
.model("vidu/viduq3-turbo_text2video")
.prompt("一只小猫在月光下奔跑")
.size("960*528")
.resolution("540P")
.duration(5)
.watermark(true)
.build();
System.out.println("please wait...");
VideoSynthesisResult result = vs.call(param);
System.out.println(JsonUtils.toJson(result));
}
public static void main(String[] args) {
try {
text2Video();
} catch (ApiException | NoApiKeyException | InputRequiredException e) {
System.out.println(e.getMessage());
}
System.exit(0);
}
}响应示例
video_url 24小时内有效,请及时下载。{
"request_id": "bebc5f6b-a081-4b02-ad29-xxxxxx",
"output": {
"task_id": "2b0e287f-ebdc-49af-82aa-xxxxxx",
"task_status": "SUCCEEDED",
"video_url": "https://prod-ss-vidu.s3.cn-northwest-1.amazonaws.com.cn/infer_92/xxx.mp4?xxx",
"orig_prompt": "一只小猫在月光下奔跑",
"submit_time": "2026-03-30 10:19:00.827",
"scheduled_time": "2026-03-30 10:19:00.879",
"end_time": "2026-03-30 10:19:28.172"
},
"usage": {
"video_count": 1,
"duration": 5.0,
"size": "960*528",
"input_video_duration": 0.0,
"output_video_duration": 5.0,
"SR": "540"
},
"status_code": 200,
"code": "",
"message": ""
}异步调用
请求示例
// Copyright (c) Alibaba, Inc. and its affiliates.
import com.alibaba.dashscope.aigc.videosynthesis.VideoSynthesis;
import com.alibaba.dashscope.aigc.videosynthesis.VideoSynthesisParam;
import com.alibaba.dashscope.aigc.videosynthesis.VideoSynthesisResult;
import com.alibaba.dashscope.exception.ApiException;
import com.alibaba.dashscope.exception.InputRequiredException;
import com.alibaba.dashscope.exception.NoApiKeyException;
import com.alibaba.dashscope.utils.JsonUtils;
import com.alibaba.dashscope.utils.Constants;
public class Text2Video {
static {
// 以下为北京地域url
Constants.baseHttpApiUrl = "https://dashscope.aliyuncs.com/api/v1";
}
// 若没有配置环境变量,请用百炼API Key将下行替换为:api_key="sk-xxx"
public static String apiKey = System.getenv("DASHSCOPE_API_KEY");
/**
* Create a video compositing task and wait for the task to complete.
*/
public static void text2Video() throws ApiException, NoApiKeyException, InputRequiredException {
VideoSynthesis vs = new VideoSynthesis();
VideoSynthesisParam param =
VideoSynthesisParam.builder()
.apiKey(apiKey)
.model("vidu/viduq3-turbo_text2video")
.prompt("一只小猫在月光下奔跑")
.size("960*528")
.resolution("540P")
.duration(5)
.watermark(true)
.build();
// 异步调用
VideoSynthesisResult task = vs.asyncCall(param);
System.out.println(JsonUtils.toJson(task));
System.out.println("please wait...");
//获取结果
VideoSynthesisResult result = vs.wait(task, apiKey);
System.out.println(JsonUtils.toJson(result));
}
public static void main(String[] args) {
try {
text2Video();
} catch (ApiException | NoApiKeyException | InputRequiredException e) {
System.out.println(e.getMessage());
}
System.exit(0);
}
}响应示例
1、创建任务的响应示例。
{
"request_id": "9b583f1b-2423-4fac-bb3f-xxxxxx",
"output": {
"task_id": "3944b819-1bbb-4da0-a230-xxxxxx",
"task_status": "PENDING"
},
"status_code": 200,
"code": "",
"message": ""
}2、查询任务结果的响应示例
video_url 24小时内有效,请及时下载。{
"request_id": "bebc5f6b-a081-4b02-ad29-xxxxxx",
"output": {
"task_id": "2b0e287f-ebdc-49af-82aa-xxxxxx",
"task_status": "SUCCEEDED",
"video_url": "https://prod-ss-vidu.s3.cn-northwest-1.amazonaws.com.cn/infer_92/xxx.mp4?xxx",
"orig_prompt": "一只小猫在月光下奔跑",
"submit_time": "2026-03-30 10:19:00.827",
"scheduled_time": "2026-03-30 10:19:00.879",
"end_time": "2026-03-30 10:19:28.172"
},
"usage": {
"video_count": 1,
"duration": 5.0,
"size": "960*528",
"input_video_duration": 0.0,
"output_video_duration": 5.0,
"SR": "540"
},
"status_code": 200,
"code": "",
"message": ""
}错误码
如果模型调用失败并返回报错信息,请参见错误信息进行解决。
常见问题
Q:size 与 resolution 必须同时传入吗?
A: 不必。二者均为可选参数,但推荐同时传入。同时传入可精准控制生成视频的宽高比,具体参见size取值。
若不同时传入,系统将按以下两种场景处理:
仅传 size:size参数会被忽略,系统强制按默认的
resolution=720P及其对应的size默认值(1280*720)处理。例如:接口返回为size="1280*720", SR=720。
仅传 resolution:按指定分辨率档位及该档位对应的 16:9 比例输出。
例如:当resolution=540P时,接口返回 size="960*528", SR=540;当resolution=1080P时,接口返回 size="1920*1080", SR=1080。