功能简介
腾讯云媒体处理(MPS)AIGC 聚合平台提供 AI 生成音乐的能力,已聚合 MiniMax 等主流音乐生成模型,开发者通过同一套 API 即可调用不同模型并获取生成结果。
说明:
计费说明
前置条件
1. 开通服务
1. 登录 腾讯云媒体处理控制台,按照引导开通 MPS 服务。
2. 获取 API 密钥:前往 API 密钥管理 获取 SecretId 和 SecretKey。
3. (可选)如需将生成结果存到 COS,还需开通对象存储 (COS) 并创建存储桶,授权 MPS_QcsRole 角色。可参考 账号授权相关 文档。
2. 安装依赖
本指南的代码示例使用 axios 作为 HTTP 客户端,但它不是必须的。您可以根据项目情况选择以下任一方式发送 HTTP 请求。
方案 | 是否需要安装 | 适用场景 |
axios(本文示例默认) | npm install axios | 已有项目在用 axios,或偏好其 API 风格。 |
Node.js 原生 fetch | 无需安装(Node.js ≥ 18 内置) | 零依赖、现代项目推荐。 |
Node.js 原生 https | 无需安装 | 兼容老版本 Node.js(< 18)。 |
如果您选择 axios:
npm install axios
如果您选择原生 fetch(Node.js ≥ 18,零依赖),将代码中的 axios.post(...) 替换为:
// 替换 axios.post 调用// 原: const resp = await axios.post(`https://${MPS_HOST}`, payload, { headers });// return resp.data;// 改为:const resp = await fetch(`https://${MPS_HOST}`, {method: 'POST',headers: headers,body: JSON.stringify(payload)});return await resp.json();
说明:
Node.js 内置的
crypto 模块即可完成签名,无需额外安装。签名部分无外部依赖。3. 密钥配置
{"tencentCloud": {"secretId": "您的 SecretId","secretKey": "您的 SecretKey","region": "ap-guangzhou"}}
注意:
安全提醒:密钥绝对不要硬编码到代码中或提交到 Git,建议使用环境变量或独立的配置文件(加入
.gitignore)。API 概览
接口 | Action | 功能 | 请求频率限制 |
CreateAigcAudioTask | 根据 Prompt + 歌词生成音乐 | 20 次/秒 | |
DescribeAigcAudioTask | 轮询音频生成进度和结果。 | 20 次/秒 |
说明:
通用信息:
请求域名:mps.tencentcloudapi.com
请求方式:POST(application/json)
API 版本:2019-06-12
签名方法:TC3-HMAC-SHA256
签名机制 (TC3-HMAC-SHA256)
腾讯云 API 3.0 使用 TC3-HMAC-SHA256 签名认证。签名过程如下:
1. 构建规范请求 (CanonicalRequest):拼接请求方法、URI、QueryString、Headers、Payload Hash。
2. 构建待签字符串 (StringToSign):拼接算法、时间戳、CredentialScope、CanonicalRequest Hash。
3. 计算签名 (Signature):用 SecretKey 逐级 HMAC 派生签名密钥,再对 StringToSign 签名。
4. 构建 Authorization Header:组装最终的认证头。
注意事项
1. 生成结果仅存储 12 小时
音频的 URL 只有12小时有效期,务必在生成后及时下载或转存到自己的 COS/服务器。
2. 频率限制
音频创建:20次/秒
音频查询:20次/秒
建议实现并发控制和请求队列,避免触发限流。
3. Prompt 长度限制
音频 Prompt:最好不要超过2000字符。
4. COS 存储
使用 StoreCosParam 可将结果直接存到指定 COS 桶,需要:
开通 COS 服务。
创建存储桶。
授权 MPS_QcsRole 角色访问该桶。
核心代码实现
1. 签名工具 (tencent-sign.js)
/*** 腾讯云 API 签名工具 (TC3-HMAC-SHA256)*/const crypto = require('crypto');function sha256(message) {return crypto.createHash('sha256').update(message).digest('hex');}function hmac256(key, message) {return crypto.createHmac('sha256', key).update(message).digest();}/*** 生成腾讯云 API V3 签名* @param {string} secretId - 腾讯云 SecretId* @param {string} secretKey - 腾讯云 SecretKey* @param {string} service - 服务名,如 'mps'* @param {string} action - 接口名,如 'CreateAigcAudioTask'* @param {string} payload - 请求体 JSON 字符串* @param {string} region - 地域,如 'ap-guangzhou'* @param {string} [version] - API 版本号,默认 '2019-06-12'* @returns {{ headers: object }} - 包含完整签名的请求头*/function signRequest(secretId, secretKey, service, action, payload, region, version) {const timestamp = Math.floor(Date.now() / 1000);const date = new Date(timestamp * 1000).toISOString().split('T')[0];// ===== 步骤1: 拼接规范请求串 =====const httpRequestMethod = 'POST';const canonicalUri = '/';const canonicalQueryString = '';const contentType = 'application/json';const canonicalHeaders =`content-type:${contentType}\\n` +`host:${service}.tencentcloudapi.com\\n` +`x-tc-action:${action.toLowerCase()}\\n`;const signedHeaders = 'content-type;host;x-tc-action';const hashedRequestPayload = sha256(payload);const canonicalRequest =`${httpRequestMethod}\\n${canonicalUri}\\n${canonicalQueryString}\\n` +`${canonicalHeaders}\\n${signedHeaders}\\n${hashedRequestPayload}`;// ===== 步骤2: 拼接待签名字符串 =====const algorithm = 'TC3-HMAC-SHA256';const credentialScope = `${date}/${service}/tc3_request`;const hashedCanonicalRequest = sha256(canonicalRequest);const stringToSign =`${algorithm}\\n${timestamp}\\n${credentialScope}\\n${hashedCanonicalRequest}`;// ===== 步骤3: 计算签名 =====const secretDate = hmac256(`TC3${secretKey}`, date);const secretService = hmac256(secretDate, service);const secretSigning = hmac256(secretService, 'tc3_request');const signature = crypto.createHmac('sha256', secretSigning).update(stringToSign).digest('hex');// ===== 步骤4: 拼接 Authorization =====const authorization =`${algorithm} Credential=${secretId}/${credentialScope}, ` +`SignedHeaders=${signedHeaders}, Signature=${signature}`;return {headers: {'Authorization': authorization,'Content-Type': contentType,'Host': `${service}.tencentcloudapi.com`,'X-TC-Action': action,'X-TC-Timestamp': String(timestamp),'X-TC-Version': version || '2019-06-12','X-TC-Region': region || ''}};}module.exports = { signRequest };
2. MPS API 封装 (mps-api.js)
const axios = require('axios');const { signRequest } = require('./tencent-sign');const MPS_HOST = 'mps.tencentcloudapi.com';const SERVICE = 'mps';/*** 通用 MPS API 调用函数*/async function callMpsApi(action, params, config) {const payload = JSON.stringify(params);const { headers } = signRequest(config.tencentCloud.secretId,config.tencentCloud.secretKey,SERVICE,action,payload,config.tencentCloud.region);const resp = await axios.post(`https://${MPS_HOST}`, payload, { headers });return resp.data;}// =============================================// 音频生成// =============================================/*** 创建 AIGC 生音频任务* @param {string} prompt - 音乐风格 / 演唱要求描述* @param {string} lyrics - 歌词文本(\\n 换行,\\n\\n 分段)* @param {object} options - 可选项*/async function createMusicTask(prompt, lyrics, options = {}) {const config = options._config; // 传入配置对象const params = {ModelName: options.modelName || 'MinimaxMusic',ModelVersion: options.modelVersion || '2.6',SceneType: 'music', // 音乐生成固定为 musicPrompt: prompt};// 输出格式(可选,默认由模型决定)if (options.outputAudioFormat) {params.OutputAudioFormat = options.outputAudioFormat;}// 歌词通过 AdditionalParameters 传入(注意:是 JSON 字符串)if (lyrics) {params.AdditionalParameters = JSON.stringify({ lyrics });}// 参考音频(可选,仅部分场景)if (options.referenceAudioUrl) {params.AudioInfos = [{ Type: 'Url', Url: options.referenceAudioUrl }];}// COS 存储(可选)if (options.storeCos) {params.StoreCosParam = options.storeCos;}const result = await callMpsApi('CreateAigcAudioTask', params, config);return result;}/*** 查询 AIGC 生音频任务* @param {string} taskId - 创建任务时返回的 TaskId* @param {object} config - 配置对象*/async function describeMusicTask(taskId, config) {const params = { TaskId: taskId };const result = await callMpsApi('DescribeAigcAudioTask', params, config);return result;}module.exports = {callMpsApi,createMusicTask,describeMusicTask};
完整使用流程
生成音乐(完整流程)
const { signRequest } = require('./tencent-sign');const axios = require('axios');const MPS_HOST = 'mps.tencentcloudapi.com';// === 配置 ===const config = {tencentCloud: {secretId: '您的 SecretId',secretKey: '您的 SecretKey',region: 'ap-guangzhou'}};// === 通用调用函数 ===async function callMpsApi(action, params) {const payload = JSON.stringify(params);const { headers } = signRequest(config.tencentCloud.secretId,config.tencentCloud.secretKey,'mps',action,payload,config.tencentCloud.region);const resp = await axios.post(`https://${MPS_HOST}`, payload, { headers });return resp.data;}// === 主流程 ===async function generateMusic() {// 第 1 步:创建音乐生成任务console.log('🎵 正在创建音乐生成任务...');const createResult = await callMpsApi('CreateAigcAudioTask', {ModelName: 'MinimaxMusic',ModelVersion: '2.6',SceneType: 'music',Prompt: '这是一个寒冷的冬天,需要女声来唱', // 风格 / 演唱要求OutputAudioFormat: 'mp3',// 歌词通过 AdditionalParameters 的 lyrics 字段传入(JSON 字符串)AdditionalParameters: JSON.stringify({lyrics: ['风吹过空荡的街','天空灰得像沉默的夜','呼出的白雾慢慢盘旋','落在肩头的是冰冷季节','', // 空行分隔段落(主歌 / 副歌)'这是一个寒冷的冬天','树枝在风里轻轻哽咽'].join('\\n')})});const taskId = createResult.Response.TaskId;console.log(`✅ 任务创建成功, TaskId: ${taskId}`);// 第 2 步:轮询查询结果let status = 'WAIT';let audioInfos = [];let errorMessage = '';while (status === 'WAIT' || status === 'RUN') {// 等待 5 秒await new Promise(resolve => setTimeout(resolve, 5000));const queryResult = await callMpsApi('DescribeAigcAudioTask', {TaskId: taskId});status = queryResult.Response.Status;console.log(`⏳ 任务状态: ${status}`);if (status === 'DONE') {// 生成成功,取出音频信息audioInfos = queryResult.Response.AudioInfos;} else if (status === 'FAIL') {// 生成失败,取出错误信息errorMessage = queryResult.Response.Message;}}// 第 3 步:取出并展示音频结果if (status === 'DONE') {console.log('🎉 音乐生成成功!');} else {console.error('❌ 生成失败:', errorMessage);}return audioInfos;}generateMusic().catch(console.error);
配置文件参考
以下是一个完整的配置示例,涵盖音频生成的所有可配置项:
{"tencentCloud": {"secretId": "您的 SecretId","secretKey": "您的 SecretKey","region": "ap-guangzhou"},"cosOutput": {"bucket": "your-bucket-name-1234567890","region": "ap-guangzhou","outputDir": "/aigc-music-output/"},"mps": {"musicGeneration": {"enabled": true,"modelName": "MinimaxMusic","modelVersion": "2.6","outputAudioFormat": "mp3"}},"concurrency": {"maxMusicTasks": 1,"pollIntervalMs": 5000}}
附录:HTTP 原始请求示例
如果您使用其他语言(Python / Go / Java 等),可以参考以下 HTTP 原始请求格式:
创建音频生成任务
POST / HTTP/1.1Host: mps.tencentcloudapi.comContent-Type: application/jsonX-TC-Action: CreateAigcAudioTask<公共请求参数>{"ModelName": "Tme","ModelVersion": "1.0","SceneType": "music","Prompt": "生成一段音乐","VideoInfos": [{"VideoUrl": "https://l***-******-tts-131140***2.c***ap-*ua****ou.myqcloud.com/251006278_1513228070381297256.mp4"}],"AudioInfos": [{"AudioUrl": "https://li**-q*******ts-1311402212*cos*ap-guangzh****yqcloud.com/25*******_1513228070381297256.wav"}],"OutputAudioFormat": "wav","ExtraParameters": {"ResourceId": "438910555_1"},"AdditionalParameters": "{\\"sequential_image_generation\\":\\"auto\\"}","Operator": "admin"}
查询任务
POST / HTTP/1.1Host: mps.tencentcloudapi.comContent-Type: application/jsonX-TC-Action: DescribeAigcAudioTask<公共请求参数>{"TaskId": "24000145-******d**-cb46b8040b684b539bbd46****e*e2fd"}