Amazon Simple Queue Service
开发人员指南
AWS 文档中描述的 AWS 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅 Amazon AWS 入门

提出查询 API 请求

在本节中,您将了解如何构建 Amazon SQS 终端节点,如何提出 GETPOST 请求以及如何解释响应。

构建终端节点

为了使用 Amazon SQS 队列,您必须构建一个终端节点。有关特定于区域的 Amazon SQS 终端节点的信息,请参阅 Amazon Web Services 一般参考

每个 Amazon SQS 终端节点都是独立的。例如,如果有两个名为 MyQueue 的队列,其中一个队列具有终端节点 sqs.cn-north-1.amazonaws.com.cn,另一个队列具有终端节点 sqs.cn-northwest-1.amazonaws.com.cn,则这两个队列不会相互共享任何数据。

以下是一个提出创建队列的请求的终端节点的示例。

https://sqs.cn-north-1.amazonaws.com.cn/ ?Action=CreateQueue &DefaultVisibilityTimeout=40 &QueueName=MyQueue &Version=2012-11-05 &AUTHPARAMS

注意

队列名称和队列 URL 区分大小写。

AUTHPARAMS 的结构取决于 API 请求的签名。有关更多信息,请参阅 Amazon Web Services 一般参考 中的签署 AWS API 请求

提出 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

以下是一个 GET 请求的示例,该请求向 Amazon SQS 队列发送一条消息。

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 中不允许使用空格,因此每个空格将在 URL 中编码为“%20”。(示例的其余部分没有进行 URL 编码,以方便您阅读。)

提出 POST 请求

Amazon SQS 的 POST 请求在 HTTP 请求的正文中以表单的形式发送查询参数。

下面是一个 Content-Type 设置为 application/x-www-form-urlencoded 的 HTTP 标头的示例。

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

该标头后跟一个 form-urlencoded POST 请求,该请求向 Amazon SQS 队列发送一条消息。各参数以和号 (&) 分隔。

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

注意

Content-Type HTTP 标头是必需的。AUTHPARAMS 对于 GET 请求是相同的。

根据客户端的 HTTP 版本,您的 HTTP 客户端可能会向 HTTP 请求添加其他项目。