トランスコードとは、オーディオファイルまたはビデオファイルを、さまざまなネットワーク帯域幅、端末デバイス、およびユーザーのニーズに適応するように、1 つ以上のオーディオファイルまたはビデオファイルに変換することです。ApsaraVideo Media Processing(MPS)コンソールで作成されたトランスコードジョブとワークフローがビジネス要件を満たしていない場合は、SubmitJobs オペレーションを呼び出してトランスコードジョブを送信できます。このトピックでは、PHP V2.0 用 MPS SDK を使用してメディアファイルをトランスコードする方法の例を示します。
トランスコードジョブの管理に使用される API オペレーションと API オペレーションのパラメーターの詳細については、SubmitJobs をご参照ください。
サンプルコード
<?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\SubmitJobsRequest;
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();
$submitJobsRequest = new SubmitJobsRequest([
// ジョブ入力。
"input" => "{\"Bucket\":\"exampleBucket\",\"Location\":\"oss-cn-hangzhou\",\"Object\":\"example.flv\",\"Referer\": \"ホットリンク保護機能を有効にするためにオブジェクトストレージサービス(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 バケット。
"outputBucket" => "exampleBucket",
// OSS バケットが存在するリージョン。
"outputLocation" => "oss-cn-hangzhou",
// MPS キューの ID。
"pipelineId" => "dd3dae411e704030b921e52698e5****"
]);
$runtime = new RuntimeOptions([]);
try {
// 必要に応じて、API オペレーションのレスポンスを表示するための独自のコードを記述します。
$client->submitJobsWithOptions($submitJobsRequest, $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));