全部產品
Search
文件中心

ApsaraVideo Media Processing:轉碼

更新時間:Oct 25, 2024

轉碼是將音視頻檔案轉換成另一個或多個音視頻檔案,以適應不同網路頻寬、不同終端裝置和不同的使用者需求。當控制台建立的轉碼任務和工作流程均無法滿足您的使用情境時,可以按需調用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));

相關文檔