AWSクエリプロトコルによるクエリ API リクエストの実行 - Amazon Simple Queue Service

翻訳は機械翻訳により提供されています。提供された翻訳内容と英語版の間で齟齬、不一致または矛盾がある場合、英語版が優先します。

AWSクエリプロトコルによるクエリ API リクエストの実行

このセクションでは、Amazon SQS エンドポイントを構築する方法、GET リクエストと POST リクエストを行う方法、およびレスポンスを解釈する方法を学びます。

エンドポイントの構築

Amazon SQSキューを使用するには、エンドポイントを構築する必要があります。Amazon SQS エンドポイントの詳細については、以下のページを参照してください。Amazon Web Services 全般のリファレンス

Amazon SQSエンドポイントはそれぞれ独立しています。たとえば、2つのキューの名前が MyQueue で、一方にはエンドポイント sqs.us-east-2.amazonaws.comがあり、もう一方にはエンドポイントsqs.eu-west-2.amazonaws.comがある場合、2つのキューは互いにどのデータも共有しません。

キューを作成するリクエストを行うエンドポイントの例を次に示します。

https://sqs.eu-west-2.amazonaws.com/ ?Action=CreateQueue &DefaultVisibilityTimeout=40 &QueueName=MyQueue &Version=2012-11-05 &AUTHPARAMS
注記

キュー名とキュー URL は大文字と小文字が区別されます。

AUTHPARAMSの構造はAPIリクエストの署名によって異なります。詳細については、「Amazon Web Services 一般リファレンス」のSigningAWSAPIリクエスト」を参照してください。

GETリクエストの作成

Amazon SQS GET リクエストは、以下で構成される URL として構造化されています。

  • エンドポイント-リクエストが作用するリソース (キュー名と URL)。たとえば: https://sqs.us-east-2.amazonaws.com/123456789012/MyQueue

  • アクション-エンドポイントに実行したい アクション。疑問符 (?) によってエンドポイントとアクションが区切られます。たとえば?Action=SendMessage&MessageBody=Your%20Message%20Textなど:

  • パラメータ — 任意のリクエストパラメータ。各パラメータはアンパサンド (&) で区切られます。次に例を示します。&Version=2012-11-05&AUTHPARAMS

以下は、Amazon SQS キューにメッセージを送信する GET リクエストの例です。

https://sqs.us-east-2.amazonaws.com/123456789012/MyQueue ?Action=SendMessage&MessageBody=Your%20message%20text &Version=2012-11-05 &AUTHPARAMS
注記

キュー名とキュー URL は大文字と小文字が区別されます。

GET リクエストは URL なので、すべてのパラメータ値を URL エンコードする必要があります。URLにはスペースを使用できないため、各スペースは「%20」としてURLエンコードされます。この例の残りの部分は、読みやすくするために URL でエンコードされていません。

POSTリクエストの作成

Amazon SQS POST リクエストは、HTTP リクエストの本文のフォームとしてクエリパラメータを送信します。

以下は、Content-Typeに設定された HTTP ヘッダーの例ですapplication/x-www-form-urlencoded

POST /123456789012/MyQueue HTTP/1.1 Host: sqs.us-east-2.amazonaws.com Content-Type: application/x-www-form-urlencoded

ヘッダーの後には、Amazon SQS キューにメッセージを送信する form-urlencoded GET リクエストが続きます。各パラメータは、アンパサンド (&)で区切られています。

Action=SendMessage &MessageBody=Your+Message+Text &Expires=2020-10-15T12%3A00%3A00Z &Version=2012-11-05 &AUTHPARAMS
注記

Content-TypeHTTPヘッダーのみが必須です。AUTHPARAMSこれは GET リクエストと同じです。

HTTPクライアントは、クライアントのHTTP バージョンによっては、他の項目を HTTPリクエストに追加する可能性があります。