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

ApsaraVideo Media Processing:クライアントを初期化する

最終更新日:Jan 12, 2025

このトピックでは、PHP V2.0 向け ApsaraVideo Media Processing(MPS)SDK のクライアントを初期化する方法について説明します。

環境変数から AccessKey ペアを取得する

環境変数 ALIBABA_CLOUD_ACCESS_KEY_IDALIBABA_CLOUD_ACCESS_KEY_SECRETLinux、macOS、および Windows で環境変数を構成する と を定義して、デフォルトの認証情報を構成できます。API オペレーションを呼び出すと、システムはデフォルトの認証情報から AccessKey ペアを読み取り、認証を完了するために使用します。詳細については、 をご参照ください。

SDK クライアントを初期化する

  1. 構成オブジェクト Darabonba\OpenApi\Models\Config を初期化します。

    use Darabonba\OpenApi\Models\Config;
    $config = new Config([
        // ALIBABA_CLOUD_ACCESS_KEY_ID 環境変数が構成されていることを確認します。
        "accessKeyId" => $accessKeyId,
        // ALIBABA_CLOUD_ACCESS_KEY_SECRET 環境変数が構成されていることを確認します。
        "accessKeySecret" => $accessKeySecret
    ]);
    // アクセスするエンドポイントを指定します。
    $config->endpoint = "ecs-cn-hangzhou.aliyuncs.com";
    
  2. クライアントをインスタンス化し、AlibabaCloud\SDK\Mts\V20140618\Mts クラスからクライアントオブジェクトを生成します。

    use AlibabaCloud\SDK\Mts\V20140618\Mts;
    
    $client = new Mts($config);

サンプルコード

この例では、SearchPipeline オペレーションが呼び出されます。

<?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\SearchPipelineRequest;
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();
        $searchPipelineRequest = new SearchPipelineRequest([
                // クエリする MPS キューの状態。
                "state" => "Paused",
                // 各ページに返すエントリの数。
                "pageSize" => 10,
                // 現在のページ番号。
                "pageNumber" => 1
        ]);
        $runtime = new RuntimeOptions([]);
        try {
            // 必要に応じて、API オペレーションのレスポンスを表示する独自のコードを記述します。
            $client->searchPipelineWithOptions($searchPipelineRequest, $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));