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

ApsaraVideo Media Processing:メディアファイルを追加する

最終更新日:Jan 12, 2025

ApsaraVideo Media Processing(MPS)のメディアライブラリにメディアファイルを追加した後、ワークフローのIDを指定してメディアファイルを処理できます。このトピックでは、MPS PHP SDK V2.0を使用してメディアライブラリにメディアファイルを追加し、特定のワークフローをトリガーしてメディアファイルを処理する方法の例を示します。

説明

メディアライブラリがワークフローのトリガールールを満たしている場合、ワークフローがトリガーされます。それ以外の場合、ワークフローはトリガーされません。詳細については、「ファイルのワークフロートリガールール」をご参照ください。

<?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\AddMediaRequest;
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();
        $addMediaRequest = new AddMediaRequest([
                // 入力ファイルのパス。
                "fileURL" => "http://bucket.oss-cn-hangzhou.aliyuncs.com/A/B/C/test.mp4",
                // メディアタイトル。
                "title" => "mytest",
                // 説明。
                "description" => "A test video",
                // メディアサムネイルのURL。
                "coverURL" => "http://bucket.oss-cn-hangzhou.aliyuncs.com/example/1.png",
                // タグ。
                "tags" => "tag1,tag2",
                // メディアワークフローのID。
                "mediaWorkflowId" => "07da6c65da7f458997336e0de192****",
                // メディアワークフローのカスタムデータ。
                "mediaWorkflowUserData" => "test",
                // メディアワークフローが指定された入力パスをサポートしているかどうかを確認するかどうかを指定します。
                "inputUnbind" => false,
                // メディアファイルが属するカテゴリのID。
                "cateId" => 123,
                // overrideParams パラメーターを設定します。
                "overrideParams" => "{“subtitleTransNodeName”:{“InputConfig”:{“Format”:”stl”,”InputFile”:{“URL”:”http://exampleBucket.oss-cn-hangzhou.aliyuncs.com/package/example/CENG.stl\"}}}}"
        ]);
        $runtime = new RuntimeOptions([]);
        try {
            // 必要に応じて、API操作のレスポンスを表示するための独自のコードを記述します。
            $client->addMediaWithOptions($addMediaRequest, $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));