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

Object Storage Service:OSS SDK for Python 2.0 を使用してリクエスト元支払いモードを有効にする

最終更新日:Oct 21, 2025

リクエスト元支払いモードがサポートされています。 バケットに対してリクエスト元支払いモードが有効になっている場合、リクエスト元はリクエスト料金とトラフィック料金を支払い、バケットの所有者はストレージコストを支払います。 バケットにアクセスしたときにリクエスト料金とトラフィック料金を支払うことなくバケット内のデータを共有するには、バケットのリクエスト元支払いモードを有効にします。

使用上の注意

  • このトピックのサンプルコードでは、中国 (杭州) リージョンのリージョン ID cn-hangzhou を使用します。 デフォルトでは、パブリックエンドポイントを使用してバケット内のリソースにアクセスします。 バケットが配置されているのと同じリージョンにある他の Alibaba Cloud サービスからバケット内のリソースにアクセスする場合は、内部エンドポイントを使用します。 OSS がサポートするリージョンとエンドポイントの詳細については、「リージョンとエンドポイント」をご参照ください。

  • リクエスト元支払いモードを設定するには、oss:PutBucketRequestPayment 権限が必要です。 リクエスト元支払いモードの設定を取得するには、oss:GetBucketRequestPayment 権限が必要です。 詳細については、「RAM ユーザーにカスタム権限を付与する」をご参照ください。

サンプルコード

バケットのリクエスト元支払いモードを有効にする

次のサンプルコードは、リクエスト元支払いモードを有効にする方法の例を示しています。

import argparse
import alibabacloud_oss_v2 as oss

# コマンドライン引数パーサーを作成し、スクリプトの目的を記述します: バケットのリクエスト支払い設定を行います。
parser = argparse.ArgumentParser(description="put bucket request payment sample")

# 必須のリージョン、バケット名、オプションのエンドポイント、支払者など、コマンドライン引数を定義します。
parser.add_argument('--region', help='The region in which the bucket is located.', required=True)
parser.add_argument('--bucket', help='The name of the bucket.', required=True)
parser.add_argument('--endpoint', help='The domain names that other services can use to access OSS')
parser.add_argument('--payer', help='Indicates who pays the download and request fees. Possible values: "Requester" or "BucketOwner"', required=True)

def main():
    # コマンドライン引数を解析して、ユーザーが入力した値を取得します。
    args = parser.parse_args()

    # ID 検証のために、環境変数からアクセス資格情報情報を読み込みます。
    credentials_provider = oss.credentials.EnvironmentVariableCredentialsProvider()

    # デフォルトの SDK 設定を使用して設定オブジェクトを作成し、認証プロバイダーを設定します。
    cfg = oss.config.load_default()
    cfg.credentials_provider = credentials_provider

    # ユーザーが指定したコマンドライン引数に基づいて、設定オブジェクトのリージョンプロパティを設定します。
    cfg.region = args.region

    # カスタムエンドポイントが指定されている場合は、設定オブジェクトのエンドポイントプロパティを更新します。
    if args.endpoint is not None:
        cfg.endpoint = args.endpoint

    # 上記の設定を使用して OSS クライアントを初期化し、OSS との対話の準備をします。
    client = oss.Client(cfg)

    # 指定されたバケットのリクエスト支払い設定を行うリクエストを送信します。
    result = client.put_bucket_request_payment(oss.PutBucketRequestPaymentRequest(
            bucket=args.bucket,  # バケット名。
            request_payment_configuration=oss.RequestPaymentConfiguration(
                payer=args.payer,  # 支払者。有効な値: "Requester" または "BucketOwner"。
            ),
    ))

    # 操作結果のステータスコードとリクエスト ID を出力して、リクエストのステータスを確認します。
    print(f'status code: {result.status_code},'
          f' request id: {result.request_id},'
          )

# このスクリプトが直接実行されると、main 関数を呼び出してロジックの処理を開始します。
if __name__ == "__main__":
    main()  # スクリプトのエントリポイント。プログラムのフローはここから始まります。

リクエスト元支払いモードの設定を照会する

次のサンプルコードは、バケットのリクエスト元支払いモードの設定を照会する方法の例を示しています。

import argparse
import alibabacloud_oss_v2 as oss

# コマンドライン引数パーサーを作成し、スクリプトの目的を記述します: バケットのリクエスト支払い設定を取得します。
parser = argparse.ArgumentParser(description="get bucket request payment sample")

# 必須のリージョン、バケット名、オプションのエンドポイントなど、コマンドライン引数を定義します。
parser.add_argument('--region', help='The region in which the bucket is located.', required=True)
parser.add_argument('--bucket', help='The name of the bucket.', required=True)
parser.add_argument('--endpoint', help='The domain names that other services can use to access OSS')

def main():
    # コマンドライン引数を解析して、ユーザーが入力した値を取得します。
    args = parser.parse_args()

    # ID 検証のために、環境変数からアクセス資格情報情報を読み込みます。
    credentials_provider = oss.credentials.EnvironmentVariableCredentialsProvider()

    # デフォルトの SDK 設定を使用して設定オブジェクトを作成し、認証プロバイダーを設定します。
    cfg = oss.config.load_default()
    cfg.credentials_provider = credentials_provider

    # ユーザーが指定したコマンドライン引数に基づいて、設定オブジェクトのリージョンプロパティを設定します。
    cfg.region = args.region

    # カスタムエンドポイントが指定されている場合は、設定オブジェクトのエンドポイントプロパティを更新します。
    if args.endpoint is not None:
        cfg.endpoint = args.endpoint

    # 上記の設定を使用して OSS クライアントを初期化し、OSS との対話の準備をします。
    client = oss.Client(cfg)

    # 指定されたバケットのリクエスト支払い設定を取得するリクエストを送信します。
    result = client.get_bucket_request_payment(oss.GetBucketRequestPaymentRequest(
            bucket=args.bucket,  # バケット名。
    ))

    # 操作結果のステータスコード、リクエスト ID、支払者情報を出力して、リクエストのステータスと設定の詳細を確認します。
    print(f'status code: {result.status_code},'
          f' request id: {result.request_id},'
          f' payer: {getattr(result.request_payment_configuration, "payer", "Not set")},'
          )

# このスクリプトが直接実行されると、main 関数を呼び出してロジックの処理を開始します。
if __name__ == "__main__":
    main()  # スクリプトのエントリポイント。プログラムのフローはここから始まります。

関連ドキュメント

  • リクエスト元支払いモードを設定するために使用される完全なサンプルコードについては、「put_bucket_request_payment.py」をご参照ください。

  • リクエスト元支払いモードの設定を取得するために使用される完全なサンプルコードについては、「get_bucket_request_payment.py」をご参照ください。