万相-视频换人API参考

更新时间:
复制为 MD 格式

万相-视频换人模型能够依据人物图片和参考视频,将视频中的主角替换为图片中的角色,同时保留原视频的场景、光照和色调,实现无缝换人。

  • 核心功能: 在不改变原始视频的动作、表情及环境的条件下,将视频中的角色替换为指定图片中的人物。

  • 适用场景:适用于二次创作、影视后期制作等需要进行角色替换的场景。

效果示例

万相-视频换人模型wan2.2-animate-mix提供标准模式wan-std和专业模式wan-pro两种服务模式,不同模式在效果和计费上存在差异,详情参见计费与限流

人物图片

参考视频

输出视频(标准模式wan-std

输出视频(专业模式wan-pro

mix_input_image

HTTP调用

您需要已获取API Key配置API Key到环境变量

重要

北京和新加坡地域拥有独立的 API Key 请求地址,不可混用,跨地域调用将导致鉴权失败或服务报错。

重要

新加坡地域的旧版域名 https://dashscope-intl.aliyuncs.com 即将下线,请及时迁移到新版域名 https://{WorkspaceId}.ap-southeast-1.maas.aliyuncs.com

由于视频生成耗时较长,HTTP API采用异步模式,调用流程分两步:

  1. 创建任务获取任务ID:发送一个请求创建任务,该请求会返回任务ID(task_id)

  2. 根据任务ID查询结果:使用task_id轮询任务状态,直到任务完成并获得视频URL。

步骤1:创建任务获取任务ID

北京地域POST https://dashscope.aliyuncs.com/api/v1/services/aigc/image2video/video-synthesis

新加坡地域POST https://{WorkspaceId}.ap-southeast-1.maas.aliyuncs.com/api/v1/services/aigc/image2video/video-synthesis

说明
  • 创建成功后,使用接口返回的 task_id 查询结果,task_id 有效期为 24 小时。请勿重复创建任务,轮询获取即可。

  • 新手指引请参见Postman

请求参数

视频换人

以下为华北2(北京)地域的URL,各地域的URL不同。

curl --location 'https://dashscope.aliyuncs.com/api/v1/services/aigc/image2video/video-synthesis' \
    --header 'X-DashScope-Async: enable' \
    --header "Authorization: Bearer $DASHSCOPE_API_KEY" \
    --header 'Content-Type: application/json' \
    --data '{
        "model": "wan2.2-animate-mix",
        "input": {
            "image_url": "https://help-static-aliyun-doc.aliyuncs.com/file-manage-files/zh-CN/20250919/bhkfor/mix_input_image.jpeg",
            "video_url": "https://help-static-aliyun-doc.aliyuncs.com/file-manage-files/zh-CN/20250919/wqefue/mix_input_video.mp4",
            "watermark": true
        },
        "parameters": {
            "mode": "wan-std"
        }
      }'

请求头(Headers)

Content-Type string (必选)

请求内容类型。此参数必须设置为application/json

Authorization string(必选)

请求身份认证。接口使用阿里云百炼API Key进行身份认证。示例值:Bearer sk-xxxx。

X-DashScope-Async string (必选)

异步处理配置参数。HTTP请求只支持异步,必须设置为enable

重要

缺少此请求头将报错:“current user api does not support synchronous calls”。

请求体(Request Body)

model string (必选)

模型名称,必须设置为wan2.2-animate-mix

input object (必选)

视频换人的输入图片和视频。

属性

image_url string (必选)

人物图片的公网可访问HTTP/HTTPS URL,不能包含中文等非ASCII字符,否则需编码后传入。

本地文件可通过上传文件获取临时URL

  • 格式限制:JPG、JPEG、PNG、BMP、WEBP

  • 尺寸限制:图像的宽度和高度都在[200,4096]像素范围内,宽高比在1:33:1范围内。

  • 大小限制:不超过5MB

  • 示例https://help-static-aliyun-doc.aliyuncs.com/file-manage-files/zh-CN/20250919/bhkfor/mix_input_image.jpeg

video_url string (必选)

参考视频的公网可访问HTTP/HTTPS URL,不能包含中文等非ASCII字符,否则需编码后传入。

本地文件可通过上传文件获取临时URL

建议:更高的分辨率和帧率可有效提升输出视频画质。

  • 格式限制:MP4、AVI、MOV

  • 尺寸限制:视频的宽度和高度[200, 2048]像素范围内,宽高比在1:33:1范围内。

  • 大小限制:不超过200MB

  • 时长限制:不小于2s且不大于30s

  • 示例https://help-static-aliyun-doc.aliyuncs.com/file-manage-files/zh-CN/20250919/wqefue/mix_input_video.mp4

watermark bool (可选)

是否添加水印标识,水印位于图片右下角,文案为“通义AI生成”。

  • false(默认值):不添加水印。

  • true:添加水印。

parameters object (必选)

属性

check_image bool (可选)

控制是否在处理前对输入图片进行检查。

  • true(默认值):在处理前检查输入图片。

  • false:跳过检查,直接处理。

mode string (必选)

服务模式,提供两种选择:

  • wan-std:标准模式。生成速度快、性价比高,适用于快速预览和基础动画。

  • wan-pro:专业模式。动画更流畅、画质更优,但处理时间和费用相应增加。

详情请参见效果示例计费与限流

响应参数

成功响应

请保存 task_id,用于查询任务状态与结果。

{
    "output": {
        "task_status": "PENDING",
        "task_id": "0385dc79-5ff8-4d82-bcb6-xxxxxx"
    },
    "request_id": "4909100c-7b5a-9f92-bfe5-xxxxxx"
}

异常响应

创建任务失败,请参见错误码进行解决。

{
    "code": "InvalidApiKey",
    "message": "No API-key provided.",
    "request_id": "7438d53d-6eb8-4596-8835-xxxxxx"
}

output object

任务输出信息。

属性

task_id string

任务ID。查询有效期24小时。

task_status string

任务状态。

枚举值

  • PENDING:任务排队中

  • RUNNING:任务处理中

  • SUCCEEDED:任务执行成功

  • FAILED:任务执行失败

  • CANCELED:任务已取消

  • UNKNOWN:任务不存在或状态未知

request_id string

请求唯一标识。可用于请求明细溯源和问题排查。

message string

请求失败的详细信息。请求成功时不会返回此参数,详情请参见错误码

code string

请求失败的错误码。请求成功时不会返回此参数,详情请参见错误码

步骤2:根据任务ID查询结果

北京

GET https://dashscope.aliyuncs.com/api/v1/tasks/{task_id}

新加坡

GET https://{WorkspaceId}.ap-southeast-1.maas.aliyuncs.com/api/v1/tasks/{task_id}

调用时请将WorkspaceId替换为真实的Workspace ID

说明
  • 轮询建议:视频生成过程约需数分钟,建议采用轮询机制,并设置合理的查询间隔(如 15 秒)来获取结果。

  • 任务状态流转:PENDING(排队中)→ RUNNING(处理中)→ SUCCEEDED(成功)/ FAILED(失败)。

  • 结果链接:任务成功后返回视频链接,有效期为 24 小时。建议在获取链接后立即下载并转存至永久存储(如阿里云 OSS)。

  • task_id 有效期24小时,超时后将无法查询结果,接口将返回任务状态为UNKNOWN

  • RPS 限制:查询接口默认RPS20。如需更高频查询或事件通知,建议配置异步任务回调

  • 更多操作:如需批量查询、取消任务等操作,请参见管理异步任务

请求参数

查询任务结果

请将0385dc79-5ff8-4d82-bcb6-xxxxxx替换为真实的task_id。

以下为华北2(北京)地域的URL,各地域的URL不同。
curl -X GET https://dashscope.aliyuncs.com/api/v1/tasks/0385dc79-5ff8-4d82-bcb6-xxxxxx \
    --header "Authorization: Bearer $DASHSCOPE_API_KEY"
请求头(Headers)

Authorization string(必选)

请求身份认证。接口使用阿里云百炼API Key进行身份认证。示例值:Bearer sk-xxxx。

URL路径参数(Path parameters)

task_id string(必选)

任务ID。

响应参数

任务执行成功

视频URL仅保留24小时,超时后会被自动清除,请及时保存生成的视频。

{
    "request_id": "a67f8716-18ef-447c-a286-xxxxxx",
    "output": {
        "task_id": "0385dc79-5ff8-4d82-bcb6-xxxxxx",
        "task_status": "SUCCEEDED",
        "submit_time": "2025-09-18 15:32:00.105",
        "scheduled_time": "2025-09-18 15:32:15.066",
        "end_time": "2025-09-18 15:34:41.898",
        "results": {
            "video_url": "http://dashscope-result-bj.oss-cn-beijing.aliyuncs.com/xxxxx.mp4?Expires=xxxxxx"
        }
    },
    "usage": {
        "video_duration": 5.2,
        "video_ratio": "standard"
    }
}

任务执行失败

若任务执行失败,task_status将置为 FAILED,并提供错误码和信息。请参见错误码进行解决。

{
    "request_id": "daad9007-6acd-9fb3-a6bc-xxxxxx",
    "output": {
        "task_id": "fe8aa114-d9f1-4f76-b598-xxxxxx",
        "task_status": "FAILED",
        "code": "InternalError",
        "message": "xxxxxx"
    }
}

output object

任务输出信息。

属性

task_id string

任务ID。查询有效期24小时。

task_status string

任务状态。

枚举值

  • PENDING:任务排队中

  • RUNNING:任务处理中

  • SUCCEEDED:任务执行成功

  • FAILED:任务执行失败

  • CANCELED:任务已取消

  • UNKNOWN:任务不存在或状态未知

submit_time string

任务提交时间。格式为 YYYY-MM-DD HH:mm:ss.SSS。

scheduled_time string

任务执行时间。格式为 YYYY-MM-DD HH:mm:ss.SSS。

end_time string

任务完成时间。格式为 YYYY-MM-DD HH:mm:ss.SSS。

results object

属性

video_url string

视频URL。仅在 task_status 为 SUCCEEDED 时返回。

链接有效期24小时,可通过此URL下载视频。视频格式为MP4(H.264 编码)。

code string

请求失败的错误码。请求成功时不会返回此参数,详情请参见错误码

message string

请求失败的详细信息。请求成功时不会返回此参数,详情请参见错误码

usage object

仅在任务成功时返回。

属性

video_duration float

生成视频的时长,单位:秒。

video_ratio string

本次请求使用的服务模式。选择标准模式wan-std时返回standard,选择专业模式wan-pro时返回pro

request_id string

请求唯一标识。可用于请求明细溯源和问题排查。

使用限制

数据时效:任务task_id和视频URL均只保留 24 小时,过期后将无法查询或下载,请及时下载视频到本地

内容审核:输入与输出内容均会经过内容安全审核,包含违规内容的请求将报错“IPInfringementSuspect”或“DataInspectionFailed”,具体参见错误码

计费与限流

  • 模型免费额度和计费单价请参见模型价格

  • 模型限流请参见万相系列

  • 计费说明:

    • 输入不计费,输出计费。按成功生成的 视频秒数 计费。

    • 模型调用失败或处理错误不产生任何费用,也不消耗免费额度

错误码

如果调用失败,请参见错误码

常见问题

Q: 如何查看模型调用量?

A: 调用数据存在约一小时延迟。请在模型观测(北京新加坡页面查看调用量、调用次数和成功率等指标。如何查看模型调用记录?

Q: 如何提升生成视频的质量?

A: 建议:

  1. 确保输入图片与参考视频中的人物画幅占比相似。

  2. 尽量保持图片和视频中人物的身材比例一致。

  3. 使用高清素材,避免使用模糊图片和低帧率视频,确保细节识别准确。

Q: 如何将临时的视频链接转为永久链接?

A: 不支持直接转换。请在后端下载视频文件后上传至对象存储服务(如阿里云 OSS),生成永久访问链接。

示例代码:下载视频到本地

import requests

def download_and_save_video(video_url, save_path):
    try:
        response = requests.get(video_url, stream=True, timeout=300) # 设置超时
        response.raise_for_status() # 如果HTTP状态码不是200,则引发异常
        with open(save_path, 'wb') as f:
            for chunk in response.iter_content(chunk_size=8192):
                f.write(chunk)
        print(f"视频已成功下载到: {save_path}")
        # 此处可以接上传到永久存储的逻辑
    except requests.exceptions.RequestException as e:
        print(f"下载视频失败: {e}")

if __name__ == '__main__':
    video_url = "http://dashscope-result-sh.oss-cn-shanghai.aliyuncs.com/xxxx"
    save_path = "video.mp4"
    download_and_save_video(video_url, save_path)

Q: 返回的视频链接可以在浏览器中直接播放吗?

A: 不建议直接播放,链接会在 24 小时后失效。请在后端下载转存后,使用永久链接播放。

Q:如何获取视频存储的访问域名白名单?

A: 模型生成的视频存储于阿里云OSS,API将返回一个临时的公网URL。若需要对该下载地址进行防火墙白名单配置,请注意:由于底层存储会根据业务情况进行动态变更,为避免过期信息影响访问,文档不提供固定的OSS域名白名单。如有安全管控需求,请联系客户经理获取最新OSS域名列表。