すべてのプロダクト
Search
ドキュメントセンター

ApsaraVideo Media Processing:メディアファイルのトランスコード

最終更新日:Jan 12, 2025

トランスコードとは、オーディオファイルまたはビデオファイルを 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));

参照