轉碼是將音視頻檔案轉換成另一個或多個音視頻檔案,以適應不同網路頻寬、不同終端裝置和不同的使用者需求。當控制台建立的轉碼任務和工作流程均無法滿足您的使用情境時,可以按需調用SubmitJobs介面進行轉碼。本文提供了Node.js SDK V2.0轉碼的操作步驟及完整的程式碼範例。
完整代碼
轉碼相關API調用及參數詳細資料請參見提交轉碼作業。
'use strict';
const Mts20140618 = require('@alicloud/mts20140618');
const OpenApi = require('@alicloud/openapi-client');
const Util = require('@alicloud/tea-util');
const Tea = require('@alicloud/tea-typescript');
class Client {
/**
* 使用AK&SK初始化帳號Client
* @return Client
* @throws Exception
*/
static createClient() {
let config = new OpenApi.Config({
// 必填,請確保代碼運行環境設定了環境變數 ALIBABA_CLOUD_ACCESS_KEY_ID。
accessKeyId: process.env['ALIBABA_CLOUD_ACCESS_KEY_ID'],
// 必填,請確保代碼運行環境設定了環境變數 ALIBABA_CLOUD_ACCESS_KEY_SECRET。
accessKeySecret: process.env['ALIBABA_CLOUD_ACCESS_KEY_SECRET'],
});
// Endpoint 請參考 https://api.aliyun.com/product/Mts
config.endpoint = `mts.cn-qingdao.aliyuncs.com`;
return new Mts20140618.default(config);
}
static async main(args) {
let client = Client.createClient();
let submitJobsRequest = new Mts20140618.SubmitJobsRequest({
//作業輸入
input: '{"Bucket":"exampleBucket","Location":"oss-cn-hangzhou","Object":"example.flv","Referer": "使用者自行在OSS控制台設定的OSS防盜鏈參數"}',
//作業輸出配置
outputs: '[{"OutputObject":"exampleOutput.mp4","TemplateId":"6181666213ab41b9bc21da8ff5ff****","WaterMarks":[{"InputFile":{"Bucket":"exampleBucket","Location":"oss-cn-hangzhou","Object":"image_01.png"},"WaterMarkTemplateId":"9b772ce2740d4d55876d8b542d47****"}],"UserData":"testid-001"}]',
//輸出檔案所在的OSS Bucket
outputBucket: 'exampleBucket',
//輸出檔案所在的 OSS Bucket 的地區(OSS Region)
outputLocation: 'oss-cn-hangzhou',
//管道ID
pipelineId: 'dd3dae411e704030b921e52698e5****',
});
let runtime = new Util.RuntimeOptions({ });
try {
// 複製代碼運行請自行列印 API 的傳回值
await client.submitJobsWithOptions(submitJobsRequest, runtime);
} catch (error) {
// 此處僅做列印展示,請謹慎對待異常處理,在工程專案中切勿直接忽略異常。
// 錯誤 message
console.log(error.message);
// 診斷地址
console.log(error.data["Recommend"]);
Util.default.assertAsString(error.message);
}
}
}
exports.Client = Client;
Client.main(process.argv.slice(2));