通义万相文生视频模型基于文本提示词,生成一段流畅的视频。支持的能力包括:
基础能力:时长灵活(5秒/10秒)、指定视频分辨率(480P/720P/1080P)、智能改写prompt、添加水印。
音频能力:支持自动配音,或传入自定义音频文件,实现音画同步。(仅wan2.5支持)
快速入口:通义万相官网在线体验
通义万相官网的功能与API支持的能力可能存在差异,具体以API文档中列出的能力为准。如有新增功能,API文档会及时更新,敬请关注。
模型概览
输入示例 | 输出视频(wan2.5) |
输入提示词:一幅史诗级可爱的场景。一只小巧可爱的卡通小猫将军,身穿细节精致的金色盔甲,头戴一个稍大的头盔,勇敢地站在悬崖上。他骑着一匹虽小但英勇的战马,说:“青海长云暗雪山,孤城遥望玉门关。黄沙百战穿金甲,不破楼兰终不还”。悬崖下方,一支由老鼠组成的、数量庞大、无穷无尽的军队正带着临时制作的武器向前冲锋。这是一个戏剧性的、大规模的战斗场景,灵感来自中国古代的战争史诗。远处的雪山上空,天空乌云密布。整体氛围是“可爱”与“霸气”的搞笑和史诗般的融合。 输入音频: |
模型名称(model) | 模型简介 | 输出视频规格 |
wan2.5-t2v-preview | 万相2.5 preview(有声视频) 新增音频能力:支持自动配音,或传入自定义音频文件 | 分辨率档位:480P、720P、1080P 视频时长:5秒,10秒 固定规格:24fps、MP4 (H.264编码) |
wan2.2-t2v-plus | 万相2.2专业版(无声视频) 较2.1模型稳定性与成功率提升,速度提升50% | 分辨率档位:480P、1080P 视频时长:5秒 固定规格:30fps、MP4 (H.264编码) |
wanx2.1-t2v-turbo | 万相2.1极速版(无声视频) | 分辨率档位:480P、720P 视频时长:5秒 固定规格:30fps、MP4 (H.264编码) |
wanx2.1-t2v-plus | 万相2.1专业版(无声视频) | 分辨率档位:720P 视频时长:5秒 固定规格:30fps、MP4 (H.264编码) |
调用前,请查阅各地域支持的模型列表与价格。
前提条件
在调用前,先获取API Key,再配置API Key到环境变量。如需通过SDK进行调用,请安装DashScope SDK。
北京和新加坡地域拥有独立的 API Key 与请求地址,不可混用,跨地域调用将导致鉴权失败或服务报错。
HTTP调用
由于文生视频任务耗时较长(通常为1-5分钟),API采用异步调用。整个流程包含 “创建任务 -> 轮询获取” 两个核心步骤,具体如下:
具体耗时受限于排队任务数和服务执行情况,请在获取结果时耐心等待。
步骤1:创建任务获取任务ID
北京地域:POST https://dashscope.aliyuncs.com/api/v1/services/aigc/video-generation/video-synthesis
新加坡地域:POST https://dashscope-intl.aliyuncs.com/api/v1/services/aigc/video-generation/video-synthesis
创建成功后,使用接口返回的
task_id
查询结果,task_id 有效期为 24 小时。请勿重复创建任务,轮询获取即可。新手指引请参见Postman。
请求参数 | 自动配音仅wan2.5-t2v-preview支持。模型已默认开启自动配音功能,无需配置;如需显式声明,可将
传入音频文件仅wan2.5-t2v-preview支持。请通过
生成无声视频生成无声视频因模型版本而异:
使用反向提示词通过 negative_prompt 排除“花朵”元素,避免其出现在视频画面中。
|
请求头(Headers) | |
Content-Type 请求内容类型。此参数必须设置为 | |
Authorization 请求身份认证。接口使用阿里云百炼API-Key进行身份认证。示例值:Bearer sk-xxxx。 | |
X-DashScope-Async 异步处理配置参数。HTTP请求只支持异步,必须设置为 重要 缺少此请求头将报错:“current user api does not support synchronous calls”。 | |
请求体(Request Body) | |
model 模型名称。示例值:wan2.2-t2v-plus。 模型列表与价格详见模型价格。 | |
input 输入的基本信息,如提示词等。 | |
parameters 图像处理参数。如设置视频分辨率、开启prompt智能改写、添加水印等。 |
响应参数 | 成功响应请保存 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,否则可能运行报错:安装或升级SDK。
wan2.5-t2v-preview模型暂不支持SDK调用。
同步调用
请求示例
from http import HTTPStatus
from dashscope import VideoSynthesis
import dashscope
import os
# 以下为北京地域url,若使用新加坡地域的模型,需将url替换为:https://dashscope-intl.aliyuncs.com/api/v1
dashscope.base_http_api_url = 'https://dashscope.aliyuncs.com/api/v1'
# 若没有配置环境变量,请用百炼API Key将下行替换为:api_key="sk-xxx"
# 新加坡和北京地域的API Key不同。获取API Key:https://help.aliyun.com/zh/model-studio/get-api-key
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='wan2.2-t2v-plus',
prompt='低对比度,在一个复古的70年代风格地铁站里,街头音乐家在昏暗的色彩和粗糙的质感中演奏。他穿着旧式夹克,手持吉他,专注地弹奏。通勤者匆匆走过,一小群人渐渐聚拢聆听。镜头慢慢向右移动,捕捉到乐器声与城市喧嚣交织的场景,背景中有老式的地铁标志和斑驳的墙面。',
prompt_extend=True,
size='832*480',
negative_prompt="",
watermark=False,
seed=12345)
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_url 有效期24小时,请及时下载视频。
{
"status_code": 200,
"request_id": "f7b696bb-a9d1-4a33-8e10-xxxxxx",
"code": null,
"message": "",
"output": {
"task_id": "24b3385f-ba19-4d76-b661-xxxxxx",
"task_status": "SUCCEEDED",
"video_url": "https://dashscope-result-sh.oss-cn-shanghai.aliyuncs.com/xxx.mp4?xxx",
"submit_time": "2025-09-12 15:24:22.376",
"scheduled_time": "2025-09-12 15:24:22.425",
"end_time": "2025-09-12 15:25:44.117",
"orig_prompt": "低对比度,在一个复古的70年代风格地铁站里,街头音乐家在昏暗的色彩和粗糙的质感中演奏。他穿着旧式夹克,手持吉他,专注地弹奏。通勤者匆匆走过,一小群人渐渐聚拢聆听。镜头慢慢向右移动,捕捉到乐器声与城市喧嚣交织的场景,背景中有老式的地铁标志和斑驳的墙面。",
"actual_prompt": "70年代复古风格地铁站内,低对比度,柔光,冷色调,人工光,中全景,平衡构图。镜头缓缓向右横移,展现一位街头音乐家在昏暗环境中专注演奏的场景。他身穿深棕色旧式夹克,坐在金属折叠椅上,手中抱着一把木质吉他,低头拨动琴弦。背景中,斑驳的灰绿色墙面带有褪色广告海报,老式红黄配色的地铁标志悬挂在上方。几名通勤者穿着复古大衣与牛仔裤,手提公文包或抱着报纸,脚步匆匆地从两侧走过。一小群人逐渐聚集在音乐家左侧,几人靠在立柱旁,一人蹲在地上点燃香烟。镜头前方,一位戴贝雷帽的女子驻足聆听,手中拎着棕色皮质购物袋。远处传来列车轰鸣声,与吉他旋律交织在一起。"
},
"usage": {
"video_count": 1,
"video_duration": 5,
"video_ratio": "832*480"
}
}
异步调用
请求示例
from http import HTTPStatus
from dashscope import VideoSynthesis
import dashscope
import os
# 以下为北京地域url,若使用新加坡地域的模型,需将url替换为:https://dashscope-intl.aliyuncs.com/api/v1
dashscope.base_http_api_url = 'https://dashscope.aliyuncs.com/api/v1'
# 若没有配置环境变量,请用百炼API Key将下行替换为:api_key="sk-xxx"
# 新加坡和北京地域的API Key不同。获取API Key:https://help.aliyun.com/zh/model-studio/get-api-key
api_key = os.getenv("DASHSCOPE_API_KEY")
def sample_async_call_t2v():
# call async api, will return the task information
# you can get task status with the returned task id.
rsp = VideoSynthesis.async_call(api_key=api_key,
model='wan2.2-t2v-plus',
prompt='一只小猫在月光下奔跑',
prompt_extend=True,
size='832*480',
negative_prompt="",
watermark=False,
seed=12345)
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(rsp)
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, will call fetch interval, and check it's in finished status.
rsp = VideoSynthesis.wait(rsp)
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": "f7b696bb-a9d1-4a33-8e10-xxxxxx",
"code": null,
"message": "",
"output": {
"task_id": "24b3385f-ba19-4d76-b661-xxxxxx",
"task_status": "SUCCEEDED",
"video_url": "https://dashscope-result-sh.oss-cn-shanghai.aliyuncs.com/xxx.mp4?xxx",
"submit_time": "2025-09-12 15:24:22.376",
"scheduled_time": "2025-09-12 15:24:22.425",
"end_time": "2025-09-12 15:25:44.117",
"orig_prompt": "低对比度,在一个复古的70年代风格地铁站里,街头音乐家在昏暗的色彩和粗糙的质感中演奏。他穿着旧式夹克,手持吉他,专注地弹奏。通勤者匆匆走过,一小群人渐渐聚拢聆听。镜头慢慢向右移动,捕捉到乐器声与城市喧嚣交织的场景,背景中有老式的地铁标志和斑驳的墙面。",
"actual_prompt": "70年代复古风格地铁站内,低对比度,柔光,冷色调,人工光,中全景,平衡构图。镜头缓缓向右横移,展现一位街头音乐家在昏暗环境中专注演奏的场景。他身穿深棕色旧式夹克,坐在金属折叠椅上,手中抱着一把木质吉他,低头拨动琴弦。背景中,斑驳的灰绿色墙面带有褪色广告海报,老式红黄配色的地铁标志悬挂在上方。几名通勤者穿着复古大衣与牛仔裤,手提公文包或抱着报纸,脚步匆匆地从两侧走过。一小群人逐渐聚集在音乐家左侧,几人靠在立柱旁,一人蹲在地上点燃香烟。镜头前方,一位戴贝雷帽的女子驻足聆听,手中拎着棕色皮质购物袋。远处传来列车轰鸣声,与吉他旋律交织在一起。"
},
"usage": {
"video_count": 1,
"video_duration": 5,
"video_ratio": "832*480"
}
}
Java SDK调用
推荐安装最新版DashScope Java SDK,否则可能运行报错:安装或升级SDK。
wan2.5-t2v-preview模型暂不支持SDK调用。
同步调用
请求示例
// 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;
import java.util.HashMap;
import java.util.Map;
public class Text2Video {
static {
// 以下为北京地域url,若使用新加坡地域的模型,需将url替换为:https://dashscope-intl.aliyuncs.com/api/v1
Constants.baseHttpApiUrl = "https://dashscope.aliyuncs.com/api/v1";
}
// 若没有配置环境变量,请用百炼API Key将下行替换为:api_key="sk-xxx"
// 新加坡和北京地域的API Key不同。获取API Key:https://www.alibabacloud.com/help/zh/model-studio/get-api-key
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();
Map<String, Object> parameters = new HashMap<>();
parameters.put("prompt_extend", true);
parameters.put("watermark", false);
parameters.put("seed", 12345);
VideoSynthesisParam param =
VideoSynthesisParam.builder()
.apiKey(apiKey)
.model("wan2.2-t2v-plus")
.prompt("低对比度,在一个复古的70年代风格地铁站里,街头音乐家在昏暗的色彩和粗糙的质感中演奏。他穿着旧式夹克,手持吉他,专注地弹奏。通勤者匆匆走过,一小群人渐渐聚拢聆听。镜头慢慢向右移动,捕捉到乐器声与城市喧嚣交织的场景,背景中有老式的地铁标志和斑驳的墙面。")
.negativePrompt("")
.size("832*480")
.parameters(parameters)
.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": "db27ee62-1148-9de4-aab9-xxxxxx",
"output": {
"task_id": "31c13f64-60e3-4822-b255-xxxxxx",
"task_status": "SUCCEEDED",
"video_url": "https://dashscope-result-sh.oss-cn-shanghai.aliyuncs.com/aaa.mp4?Expires=xxx"
},
"usage": {
"video_count": 1,
"video_duration": 5,
"video_ratio": "832*480"
}
}
异步调用
请求示例
// Copyright (c) Alibaba, Inc. and its affiliates.
import com.alibaba.dashscope.aigc.videosynthesis.VideoSynthesis;
import com.alibaba.dashscope.aigc.videosynthesis.VideoSynthesisListResult;
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.task.AsyncTaskListParam;
import com.alibaba.dashscope.utils.JsonUtils;
import com.alibaba.dashscope.utils.Constants;
import java.util.HashMap;
import java.util.Map;
public class Text2Video {
static {
// 以下为北京地域url,若使用新加坡地域的模型,需将url替换为:https://dashscope-intl.aliyuncs.com/api/v1
Constants.baseHttpApiUrl = "https://dashscope.aliyuncs.com/api/v1";
}
// 若没有配置环境变量,请用百炼API Key将下行替换为:api_key="sk-xxx"
// 新加坡和北京地域的API Key不同。获取API Key:https://www.alibabacloud.com/help/zh/model-studio/get-api-key
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();
Map<String, Object> parameters = new HashMap<>();
parameters.put("prompt_extend", true);
parameters.put("watermark", false);
parameters.put("seed", 12345);
VideoSynthesisParam param =
VideoSynthesisParam.builder()
.apiKey(apiKey)
.model("wan2.2-t2v-plus")
.prompt("低对比度,在一个复古的70年代风格地铁站里,街头音乐家在昏暗的色彩和粗糙的质感中演奏。他穿着旧式夹克,手持吉他,专注地弹奏。通勤者匆匆走过,一小群人渐渐聚拢聆听。镜头慢慢向右移动,捕捉到乐器声与城市喧嚣交织的场景,背景中有老式的地铁标志和斑驳的墙面。")
.negativePrompt("")
.size("832*480")
.parameters(parameters)
.build();
// 异步调用
VideoSynthesisResult task = vs.asyncCall(param);
System.out.println(JsonUtils.toJson(task));
System.out.println("please wait...");
//获取结果
// apiKey 已经配置在环境变量,因此这里可以设置为 null
VideoSynthesisResult result = vs.wait(task, null);
System.out.println(JsonUtils.toJson(result));
}
// 获取任务列表
public static void listTask() throws ApiException, NoApiKeyException {
VideoSynthesis is = new VideoSynthesis();
AsyncTaskListParam param = AsyncTaskListParam.builder().build();
VideoSynthesisListResult result = is.list(param);
System.out.println(result);
}
// 获取单个任务结果
public void fetchTask(String taskId) throws ApiException, NoApiKeyException {
VideoSynthesis is = new VideoSynthesis();
// 如果已设置 DASHSCOPE_API_KEY 为环境变量,apiKey 可为空。
VideoSynthesisResult result = is.fetch(taskId, null);
System.out.println(result.getOutput());
System.out.println(result.getUsage());
}
public static void main(String[] args) {
try {
text2Video();
} catch (ApiException | NoApiKeyException | InputRequiredException e) {
System.out.println(e.getMessage());
}
System.exit(0);
}
}
响应示例
1、创建任务的响应示例。
{
"request_id": "5dbf9dc5-4f4c-9605-85ea-xxxxxxxx",
"output": {
"task_id": "7277e20e-aa01-4709-xxxxxxxx",
"task_status": "PENDING"
}
}
2、查询任务结果的响应示例
video_url 有效期24小时,请及时下载视频。
{
"request_id": "1625235c-c13e-93ec-aff7-xxxxxxxx",
"output": {
"task_id": "464a5e46-79a6-46fd-9823-xxxxxxxx",
"task_status": "SUCCEEDED",
"video_url": "https://dashscope-result-sh.oss-cn-shanghai.aliyuncs.com/aaa.mp4?Expires=xxx"
},
"usage": {
"video_count": 1,
"video_duration": 5,
"video_ratio": "1920*1080"
}
}
使用限制
数据时效:任务task_id和 视频url均只保留 24 小时,过期后将无法查询或下载。
音频支持:wan2.5 支持有声视频(自动配音或上传自定义音频)。wan2.2 及早期版本仅输出无声视频,如有需要,可通过语音合成生成音频。
内容审核:输入的 prompt 和输出的视频均会经过内容安全审核,包含违规内容的请求将报错“IPInfringementSuspect”或“DataInspectionFailed”,具体参见错误信息。
网络访问配置:视频链接存储于阿里云 OSS,如果业务系统因安全策略无法访问外部OSS链接,请将以下 OSS 域名加入网络访问白名单。
# OSS域名列表 dashscope-result-bj.oss-cn-beijing.aliyuncs.com dashscope-result-hz.oss-cn-hangzhou.aliyuncs.com dashscope-result-sh.oss-cn-shanghai.aliyuncs.com dashscope-result-wlcb.oss-cn-wulanchabu.aliyuncs.com dashscope-result-zjk.oss-cn-zhangjiakou.aliyuncs.com dashscope-result-sz.oss-cn-shenzhen.aliyuncs.com dashscope-result-hy.oss-cn-heyuan.aliyuncs.com dashscope-result-cd.oss-cn-chengdu.aliyuncs.com dashscope-result-gz.oss-cn-guangzhou.aliyuncs.com dashscope-result-wlcb-acdr-1.oss-cn-wulanchabu-acdr-1.aliyuncs.com
关键参数说明
音频设置
支持的模型:wan2.5-t2v-preview。
音频设置:通过input.audio_url
和 parameters.audio
参数组合控制音频行为,参数优先级:audio_url > audio
。支持三种模式:
生成无声视频
参数设置:不传audio_url,且 audio 为 false。
适用场景:纯视觉内容展示,后期自行添加音频或配乐。
自动生成音频
参数设置:不传audio_url,且 audio 为 true。
效果说明:模型根据提示词和画面内容,自动生成匹配的背景音频或音乐。
使用自定义音频
参数设置:传入 audio_url(此时 audio参数无效)。
效果说明:视频画面会尝试与音频内容对齐(如口型、节奏等)。
计费与限流
错误码
如果模型调用失败并返回报错信息,请参见错误信息进行解决。
常见问题
Q: 如何查看模型调用量?
A: 模型调用完一小时后,请在模型观测页面,查看模型的调用次数、成功率等指标。如何查看模型调用记录?
Q: 如何将临时的视频链接转为永久链接?
A: 不能直接转换该链接。正确的做法是:后端服务获取到url后,通过代码下载该视频文件,然后将其上传到永久对象存储服务(如阿里云 OSS),生成一个新的、永久访问链接。
Q: 返回的视频链接可以在浏览器中直接播放吗?
A: 不建议这样做,因为链接会在 24 小时后失效。最佳实践是后端下载转存后,使用永久链接进行视频播放。