

AWS SDK for JavaScript v2 はサポート終了となりました。[AWS SDK for JavaScript v3](https://docs.aws.amazon.com//sdk-for-javascript/v3/developer-guide/) に移行することをお勧めします。その他の詳細、移行方法については、こちらの[発表内容](https://aws.amazon.com/blogs//developer/announcing-end-of-support-for-aws-sdk-for-javascript-v2/)を参照してください。

# Amazon SQS でのメッセージの送受信
<a name="sqs-examples-send-receive-messages"></a>

![\[JavaScript code example that applies to Node.js execution\]](http://docs.aws.amazon.com/ja_jp/sdk-for-javascript/v2/developer-guide/images/nodeicon.png)

**この Node.js コード例は以下を示しています。**
+ キューでメッセージを送信する方法。
+ キューでメッセージを受信する方法。
+ キューでメッセージを削除する方法。

## シナリオ
<a name="sqs-examples-send-receive-messages-scenario"></a>

この例では、一連の Node.js モジュールはメッセージの送受信に使用されます。Node.js モジュールは SDK for JavaScript を使用して、`AWS.SQS` クライアントクラスの以下のメソッドを使用してメッセージを送受信します。
+ [https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/SQS.html#sendMessage-property](https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/SQS.html#sendMessage-property)
+ [https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/SQS.html#receiveMessage-property](https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/SQS.html#receiveMessage-property)
+ [https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/SQS.html#deleteMessage-property](https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/SQS.html#deleteMessage-property)

Amazon SQS メッセージの詳細については、*Amazon Simple Queue Service デベロッパーガイド*の [Amazon SQS キューへのメッセージの送信](https://docs.aws.amazon.com/AWSSimpleQueueService/latest/SQSDeveloperGuide/sqs-send-message.html)および [Amazon SQS キューからのメッセージの受信および削除](https://docs.aws.amazon.com/AWSSimpleQueueService/latest/SQSDeveloperGuide/sqs-receive-delete-message.html)を参照してください。

## 前提条件タスク
<a name="sqs-examples-send-receive-messages-prerequisites"></a>

この例をセットアップして実行するには、まず次のタスクを完了する必要があります。
+ Node.js をインストールします。Node.js をインストールする方法の詳細については、[Node.js ウェブサイト](https://nodejs.org)を参照してください。
+ ユーザーの認証情報を使用して、共有設定ファイルを作成します。共有認証情報ファイルの提供の詳細については、[共有認証情報ファイルから Node.js に認証情報をロードする](loading-node-credentials-shared.md) を参照してください。
+ Amazon SQS キューを作成します。キュー作成の例については、「[Amazon SQS でのキューの使用](sqs-examples-using-queues.md)」を参照してください。

## キューへのメッセージ送信
<a name="sqs-examples-send-receive-messages-sending"></a>

`sqs_sendmessage.js` というファイル名で Node.js モジュールを作成します。前に示したように SDK を必ず設定します。Amazon SQS にアクセスするには、`AWS.SQS` サービスオブジェクトを作成します。メッセージに必要なパラメータを含む JSON オブジェクトを作成します。これには、このメッセージの送信先となるキューの URL を含める必要があります。この例で、メッセージは、フィクションのベストセラーの一覧にある本についての詳細 (タイトル、著者、および一覧にある週の数) を提供します。

`sendMessage` メソッドを呼び出します。コールバックは、メッセージの一意の ID を返します。

```
// Load the AWS SDK for Node.js
var AWS = require("aws-sdk");
// Set the region
AWS.config.update({ region: "REGION" });

// Create an SQS service object
var sqs = new AWS.SQS({ apiVersion: "2012-11-05" });

var params = {
  // Remove DelaySeconds parameter and value for FIFO queues
  DelaySeconds: 10,
  MessageAttributes: {
    Title: {
      DataType: "String",
      StringValue: "The Whistler",
    },
    Author: {
      DataType: "String",
      StringValue: "John Grisham",
    },
    WeeksOn: {
      DataType: "Number",
      StringValue: "6",
    },
  },
  MessageBody:
    "Information about current NY Times fiction bestseller for week of 12/11/2016.",
  // MessageDeduplicationId: "TheWhistler",  // Required for FIFO queues
  // MessageGroupId: "Group1",  // Required for FIFO queues
  QueueUrl: "SQS_QUEUE_URL",
};

sqs.sendMessage(params, function (err, data) {
  if (err) {
    console.log("Error", err);
  } else {
    console.log("Success", data.MessageId);
  }
});
```

この例を実行するには、コマンドラインに次のように入力します。

```
node sqs_sendmessage.js
```

 このサンプルコードは、[このGitHub](https://github.com/awsdocs/aws-doc-sdk-examples/tree/master/javascript/example_code/sqs/sqs_sendmessage.js)にあります。

## キューからのメッセージの受信および削除
<a name="sqs-examples-send-receive-messages-receiving"></a>

`sqs_receivemessage.js` というファイル名で Node.js モジュールを作成します。前に示したように SDK を必ず設定します。Amazon SQS にアクセスするには、`AWS.SQS` サービスオブジェクトを作成します。メッセージに必要なパラメータを含む JSON オブジェクトを作成します。これには、メッセージを受信するキューの URL を含める必要があります。この例では、パラメータはすべてのメッセージ属性の受信、および 10 以下のメッセージの受信を指定します。

`receiveMessage` メソッドを呼び出します。コールバックは `Message` オブジェクトの配列を返します。その配列から、そのメッセージを後で削除するために使用する各メッセージについての `ReceiptHandle` を取得できます。メッセージの削除に必要なパラメータを含む別の JSON オブジェクトを作成します。これは、キューの URL と `ReceiptHandle` の値です。受信したメッセージを削除するには、`deleteMessage` メソッドを呼び出します。

```
// Load the AWS SDK for Node.js
var AWS = require("aws-sdk");
// Set the region
AWS.config.update({ region: "REGION" });

// Create an SQS service object
var sqs = new AWS.SQS({ apiVersion: "2012-11-05" });

var queueURL = "SQS_QUEUE_URL";

var params = {
  AttributeNames: ["SentTimestamp"],
  MaxNumberOfMessages: 10,
  MessageAttributeNames: ["All"],
  QueueUrl: queueURL,
  VisibilityTimeout: 20,
  WaitTimeSeconds: 0,
};

sqs.receiveMessage(params, function (err, data) {
  if (err) {
    console.log("Receive Error", err);
  } else if (data.Messages) {
    var deleteParams = {
      QueueUrl: queueURL,
      ReceiptHandle: data.Messages[0].ReceiptHandle,
    };
    sqs.deleteMessage(deleteParams, function (err, data) {
      if (err) {
        console.log("Delete Error", err);
      } else {
        console.log("Message Deleted", data);
      }
    });
  }
});
```

この例を実行するには、コマンドラインに次のように入力します。

```
node sqs_receivemessage.js
```

 このサンプルコードは、[このGitHub](https://github.com/awsdocs/aws-doc-sdk-examples/tree/master/javascript/example_code/sqs/sqs_receivemessage.js)にあります。