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

ApsaraVideo Media Processing:メディアワークフローの作成

最終更新日:Jan 12, 2025

複数のビットレート、オーディオトラック、字幕、および形式を含むビデオを制作する場合、または指定されたシーケンスまたは条件に基づいて複数のジョブを実行する場合は、ワークフローを作成できます。 ワークフローでは、トランスコーディング、分析、スナップショット、パッケージ化またはカプセル化、レビュー、メディアフィンガープリント抽出、インテリジェントサムネイル設定などのジョブを実行するためのノードを設定できます。 このトピックでは、PHP V2.0 用 ApsaraVideo Media Processing (MPS) SDK を使用してメディアワークフローを作成する方法の例を示します。

サンプルコード

<?php

namespace AlibabaCloud\SDK\Sample;

use AlibabaCloud\SDK\Mts\V20140618\Mts;
use \Exception;
use AlibabaCloud\Tea\Exception\TeaError;
use AlibabaCloud\Tea\Utils\Utils;

use Darabonba\OpenApi\Models\Config;
use AlibabaCloud\SDK\Mts\V20140618\Models\AddMediaWorkflowRequest;
use AlibabaCloud\Tea\Utils\Utils\RuntimeOptions;

class Sample {

    /**
     * AccessKey ID と AccessKey シークレットを使用してクライアントを初期化します。
     * @return Mts Client
     */
    public static function createClient(){

        $config = new Config([
                // 必須。 ALIBABA_CLOUD_ACCESS_KEY_ID 環境変数が設定されていることを確認します。
                "accessKeyId" => getenv("ALIBABA_CLOUD_ACCESS_KEY_ID"),
                // 必須。 ALIBABA_CLOUD_ACCESS_KEY_SECRET 環境変数が設定されていることを確認します。
                "accessKeySecret" => getenv("ALIBABA_CLOUD_ACCESS_KEY_SECRET")
        ]);
        $config->endpoint = "mts.cn-hangzhou.aliyuncs.com";
        return new Mts($config);
    }

    /**
     * @param string[] $args
     * @return void
     */
    public static function main($args){
        $client = self::createClient();
        $addMediaWorkflowRequest = new AddMediaWorkflowRequest([
                // メディアワークフローの名前。
                "name" => "mediaworkflow-example",
                // メディアワークフローのトポロジ。
                "topology" => "{\"Activities\": {\"mediaworkflow-example\": {\"Parameters\": {\"Outputs\": \"[{\"OutputObject\":\"examplebucket/output/{RunId}/TRANSCODE_165941222****/{FileName}\",\"TemplateId\":\"S00000001-200010\",\"TemplateName\":\"MP4-Low definition\"}]\",\"OutputBucket\": \"examplebucket\",\"OutputLocation\": \"oss-cn-shanghai\"},\"Type\": \"Transcode\"},\"Act-Start\": {\"Parameters\": {\"PipelineId\": \"a7d481f07d8c45da88c71853ce7d****\",\"InputFile\": \"{\"Bucket\":\"example-input\",\"Location\":\"oss-cn-shanghai\",\"ObjectPrefix\":\"mps-test/input/\"}\"},\"Type\": \"Start\"},\"Act-Report\": {\"Parameters\": {\"PublishType\": \"Manual\"},\"Type\": \"Report\"}},\"Dependencies\": {\"mediaworkflow-example\": [\"Act-Report\"],\"Act-Start\": [\"mediaworkflow-example\"],\"Act-Report\": []}}",
                // トリガーモード。
                "triggerMode" => "OssAutoTrigger"
        ]);
        $runtime = new RuntimeOptions([]);
        try {
            // 必要に応じて、API操作のレスポンスを表示するための独自のコードを記述します。
            $client->addMediaWorkflowWithOptions($addMediaWorkflowRequest, $runtime);
        }
        catch (Exception $error) {
            if (!($error instanceof TeaError)) {
                $error = new TeaError([], $error->getMessage(), $error->getCode(), $error);
            }
            // 実際のビジネスシナリオでは、例外を慎重に処理し、プロジェクトで例外を無視しないでください。 この例では、エラーメッセージは参照用にのみ表示されます。
            // エラーメッセージ。
            var_dump($error->message);
            // 対応するエラー診断ページの URL。
            var_dump($error->data["Recommend"]);
            Utils::assertAsString($error->message);
        }
    }
}
$path = __DIR__ . \DIRECTORY_SEPARATOR . '..' . \DIRECTORY_SEPARATOR . 'vendor' . \DIRECTORY_SEPARATOR . 'autoload.php';
        if (file_exists($path)) {
require_once $path;
}
Sample::main(array_slice($argv, 1));

参照