トランスコードとは、オーディオファイルまたはビデオファイルを 1 つ以上の別のオーディオファイルまたはビデオファイルに変換して、さまざまなネットワーク帯域幅、端末デバイス、およびユーザーニーズに適応させることです。 ApsaraVideo Media Processing(MPS)コンソールで作成されたトランスコードジョブとワークフローがビジネス要件を満たせない場合は、SubmitJobs オペレーションを呼び出してトランスコードジョブを送信できます。このトピックでは、Node.js V2.0 用 MPS SDK を使用してメディアファイルをトランスコードする例を示します。
サンプルコード
トランスコードジョブの管理に使用される API オペレーションと API オペレーションのパラメーターの詳細については、SubmitJobs をご参照ください。
'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 {
/**
* AccessKey ID と AccessKey シークレットを使用してクライアントを初期化します。
* @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'],
});
// エンドポイントを指定します。 詳細については、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": "The parameter that you set in the Object Storage Service (OSS) console to enable the hotlink protection feature"}',
// ジョブ出力設定。
outputs: '[{"OutputObject":"exampleOutput.mp4","TemplateId":"6181666213ab41b9bc21da8ff5ff****","WaterMarks":[{"InputFile":{"Bucket":"exampleBucket","Location":"oss-cn-hangzhou","Object":"image_01.png"},"WaterMarkTemplateId":"9b772ce2740d4d55876d8b542d47****"}],"UserData":"testid-001"}]',
// 入力ファイルを保存する OSS バケット。
outputBucket: 'exampleBucket',
// OSS バケットが存在するリージョン。
outputLocation: 'oss-cn-hangzhou',
// MPS キューの ID。
pipelineId: 'dd3dae411e704030b921e52698e5****',
});
let runtime = new Util.RuntimeOptions({ });
try {
// 必要に応じて、API オペレーションのレスポンスを表示するための独自のコードを記述します。
await client.submitJobsWithOptions(submitJobsRequest, runtime);
} catch (error) {
// 実際のビジネスシナリオでは、例外を慎重に処理し、プロジェクトで例外を無視しないでください。 この例では、エラーメッセージは参照用にのみ表示されます。
// エラーメッセージ。
console.log(error.message);
// 対応するエラー診断ページの URL。
console.log(error.data["Recommend"]);
Util.default.assertAsString(error.message);
}
}
}
exports.Client = Client;
Client.main(process.argv.slice(2));