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

ApsaraVideo Media Processing:OSS URLに基づいてメディアファイルを照会する

最終更新日:Jan 12, 2025

ワークフローを使用してライブストリームからビデオオンデマンド(VOD)ファイルを作成する場合、ライブストリームのメディアIDを取得できません。この場合、QueryMediaListByURL オペレーションを呼び出して、オブジェクトストレージサービス(OSS)URLを使用してライブストリームを照会できます。

import os
import sys

from typing import List

from alibabacloud_mts20140618.client import Client as Mts20140618Client
from alibabacloud_tea_openapi import models as open_api_models
from alibabacloud_mts20140618 import models as mts_20140618_models
from alibabacloud_tea_util import models as util_models
from alibabacloud_tea_util.client import Client as UtilClient


class Sample:
    def __init__(self):
        pass

    @staticmethod
    def create_client() -> Mts20140618Client:
        """
        AccessKey IDとAccessKeyシークレットを使用してクライアントを初期化します。
        @return: Client
        @throws Exception
        """
        config = open_api_models.Config(
            # 必須。 ALIBABA_CLOUD_ACCESS_KEY_ID 環境変数が設定されていることを確認します。
            access_key_id=os.environ['ALIBABA_CLOUD_ACCESS_KEY_ID'],
            # 必須。 ALIBABA_CLOUD_ACCESS_KEY_SECRET 環境変数が設定されていることを確認します。
            access_key_secret=os.environ['ALIBABA_CLOUD_ACCESS_KEY_SECRET']
        )
        config.endpoint = f'mts.cn-hangzhou.aliyuncs.com'
        return Mts20140618Client(config)

    @staticmethod
    def main(
        args: List[str],
    ) -> None:
        client = Sample.create_client()
        query_media_list_by_urlrequest = mts_20140618_models.QueryMediaListByURLRequest(
            # 照会するメディアファイルのURL。
            file_urls='http://example-bucket-****.oss-cn-shanghai.aliyuncs.com/example.mp4',
            # レスポンスに再生情報を含めるかどうかを指定します。
            include_play_list=True,
            # レスポンスにスナップショット情報を含めるかどうかを指定します。
            include_snapshot_list=True,
            # レスポンスにメディア情報を含めるかどうかを指定します。
            include_media_info=True,
            # レスポンスに概要を含めるかどうかを指定します。
            include_summary_list=True
        )
        runtime = util_models.RuntimeOptions()
        try:
            # 必要に応じて、APIオペレーションのレスポンスを表示するための独自のコードを記述します。
            client.query_media_list_by_urlwith_options(query_media_list_by_urlrequest, runtime)
        except Exception as error:
            # 実際のビジネスシナリオでは、例外を慎重に処理し、プロジェクトで例外を無視しないでください。 この例では、エラーメッセージは参照用にのみ表示されます。
            # エラーメッセージ。
            print(error.message)
            # 対応するエラー診断ページのURL。
            print(error.data.get("Recommend"))
            UtilClient.assert_as_string(error.message)

    @staticmethod
    async def main_async(
        args: List[str],
    ) -> None:
        client = Sample.create_client()
        query_media_list_by_urlrequest = mts_20140618_models.QueryMediaListByURLRequest(
            # 照会するメディアファイルのURL。
            file_urls='http://example-bucket-****.oss-cn-shanghai.aliyuncs.com/example.mp4',
            # レスポンスに再生情報を含めるかどうかを指定します。
            include_play_list=True,
            # レスポンスにスナップショット情報を含めるかどうかを指定します。
            include_snapshot_list=True,
            # レスポンスにメディア情報を含めるかどうかを指定します。
            include_media_info=True,
            # レスポンスに概要を含めるかどうかを指定します。
            include_summary_list=True
        )
        runtime = util_models.RuntimeOptions()
        try:
            # 必要に応じて、APIオペレーションのレスポンスを表示するための独自のコードを記述します。
            await client.query_media_list_by_urlwith_options_async(query_media_list_by_urlrequest, runtime)
        except Exception as error:
            # 実際のビジネスシナリオでは、例外を慎重に処理し、プロジェクトで例外を無視しないでください。 この例では、エラーメッセージは参照用にのみ表示されます。
            # エラーメッセージ。
            print(error.message)
            # 対応するエラー診断ページのURL。
            print(error.data.get("Recommend"))
            UtilClient.assert_as_string(error.message)


if __name__ == '__main__':
    Sample.main(sys.argv[1:])