サーバー認証
デバイスまたは他のクライアントが AWS IoT Core に接続を試みると、AWS IoT Core サーバーはデバイスがサーバーを認証するために使用する X.509 証明書を送信します。認証は、X.509 証明書チェーンの検証により TLS レイヤーで行われます。これは、HTTPS URL にアクセスしたときにブラウザで使用される方法と同じです。独自の認証機関からの証明書を使用する場合は、「CA 証明書の管理」を参照してください。
デバイスまたは他のクライアントが AWS IoT Core エンドポイントへの TLS 接続を確立すると、AWS IoT Core はデバイスが AWS IoT Core を偽装する別のサーバーではなく AWS IoT Core と通信していることを確認するために使用する証明書チェーンを提示します。表示されるチェーンは、デバイスが接続しているエンドポイントのタイプと、TLS ハンドシェイク中にクライアントと AWS IoT Core がネゴシエートした暗号スイートの組み合わせによって異なります。
エンドポイントタイプ
AWS IoT Core は、iot:Data
と iot:Data-ATS
の 2 つの異なるデータエンドポイントタイプをサポートしています。iot:Data
エンドポイントは、VerVeriSign Class 3 Public Primary G5 Root CA 証明書iot:Data-ATS
エンドポイントは、Amazon Trust Services
ATS エンドポイントによって提示された証明書は、Starfield によってクロス署名されています。一部の TLS クライアント実装では、信頼のルートを検証する必要があり、Starfield CA 証明書がクライアントの信頼ストアにインストールされている必要があります。
警告
証明書全体 (発行者名など) をハッシュする証明書固定方法を使用することはお勧めしません。これは、提供する ATS 証明書が Starfield によってクロス署名され、発行者名が異なるため、証明書の検証に失敗するためです。
デバイスが Symantec または Verisign CA 証明書を必要としない限り、iot:Data-ATS
エンドポイントを使用します。Symantec および Verisign 証明書は廃止され、ほとんどのウェブブラウザでサポートされなくなりました。
describe-endpoint
コマンドを使用して ATS エンドポイントを作成できます。
aws iot describe-endpoint --endpoint-type iot:Data-ATS
この describe-endpoint
コマンドは、次の形式でエンドポイントを返します。
account-specific-prefix
.iot.your-region
.amazonaws.com
describe-endpoint
が初めて呼び出されると、エンドポイントが作成されます。以降の describe-endpoint
への呼び出しはすべて、同じエンドポイントを返します。
下位互換性のために、AWS IoT Core は引き続き Symantec のエンドポイントをサポートします。詳細については、「AWS IoT Core による Symantec 認証局が今後信頼されなくなることに伴う問題への対応方法
注記
iot:Data-ATS
コンソールに AWS IoT Core エンドポイントを表示するには、[設定] を選択します。コンソールには iot:Data-ATS
エンドポイントのみが表示されます。デフォルトでは、describe-endpoint
コマンドは下位互換性のために iot:Data
エンドポイントを表示します。iot:Data-ATS
エンドポイントを表示するには、前の例のように --endpointType
パラメータを指定します。
IotDataPlaneClient
SDK for Java を使用した AWS の作成
デフォルトでは、AWS SDK for Java - バージョン 2IotDataPlaneClient
エンドポイントを使用して iot:Data
が作成されます。iot:Data-ATS
エンドポイントを使用するクライアントを作成するには、以下を実行する必要があります。
-
DescribeEndpoint API を使用して
iot:Data-ATS
エンドポイントを作成します。 -
IotDataPlaneClient
を作成するときに、そのエンドポイントを指定します。
次の例では、これらのオペレーションの両方を実行します。
public void setup() throws Exception { IotClient client = IotClient.builder().credentialsProvider(CREDENTIALS_PROVIDER_CHAIN).region(Region.US_EAST_1).build(); String endpoint = client.describeEndpoint(r -> r.endpointType("iot:Data-ATS")).endpointAddress(); iot = IotDataPlaneClient.builder() .credentialsProvider(CREDENTIALS_PROVIDER_CHAIN) .endpointOverride(URI.create("https://" + endpoint)) .region(Region.US_EAST_1) .build(); }
サーバー認証用の CA 証明書
使用しているデータエンドポイントのタイプとネゴシエートした暗号スイートに応じて、AWS IoT Core サーバー認証証明書は次のルート CA 証明書のいずれかによって署名されます。
VeriSign エンドポイント (レガシー)
-
RSA 2048 ビットキー: VeriSign クラス 3 Public Primary G5 ルート CA 証明書
Amazon Trust Services エンドポイント (推奨)
注記
場合によって、以下のリンクを右クリックし、[Save link as...] (名前を付けてリンク先を保存) を選択して、これらの証明書をファイルとして保存する必要があります。
-
RSA 2048 ビットキー: Amazon Root CA 1
。 -
RSA 4096 ビットキー: Amazon Root CA 2。将来の利用のために予約されています。
-
ECC 256 ビットキー: Amazon Root CA 3
。 -
ECC 384 ビットキー: Amazon Root CA 4。将来の利用のために予約されています。
これらの証明書はすべて、 Starfield ルート CA 証明書
サーバー認証のガイドライン
AWS IoT Core サーバー認証証明書を検証するデバイスの機能に影響を与える可能性のある多くの変数があります。例えば、デバイスのメモリ制限が大きすぎてルート CA 証明書をすべて保持できない場合や、デバイスが証明書検証の標準以外の方法を実装している場合があります。これらの理由から、次のガイドラインに従うことをお勧めします。
-
ATS エンドポイントを使用して、サポートされているすべての Amazon Root CA 証明書をインストールすることをお勧めします。
-
これらの証明書をすべてデバイスに保存できず、デバイスが ECC ベースの検証を使用していない場合は、Amazon Root CA 3
および Amazon Root CA 4 ECC 証明書を省略できます。デバイスが RSA ベースの証明書検証を実装していない場合は、Amazon Root CA 1 および Amazon Root CA 2 RSA 証明書を省略できます。場合によって、以下のリンクを右クリックし、[Save link as...] (名前を付けてリンク先を保存) を選択して、これらの証明書をファイルとして保存する必要があります。 -
ATS エンドポイントに接続するときにサーバー証明書の検証の問題が発生した場合は、関連するクロス署名付き Amazon ルート CA 証明書を信頼ストアに追加してみてください。場合によって、以下のリンクを右クリックし、[Save link as...] (名前を付けてリンク先を保存) を選択して、これらの証明書をファイルとして保存する必要があります。
-
相互署名済みの Amazon Root CA 2
- 将来の使用のために予約済みです。 -
相互署名済みの Amazon Root CA 4
- 将来の使用のために予約済みです。
-
サーバー証明書の検証の問題が発生した場合は、デバイスがルート CA を明示的に信頼する必要がある可能性があります。Starfield Root CA Certificate
を信頼ストアに追加してみてください。 -
上記の手順を実行しても問題が解決しない場合は、AWS デベロッパーサポート
にお問い合わせください。
注記
CA 証明書には有効期限があり、その後、サーバー証明書の検証には使用できません。有効期限が切れる前に CA 証明書を交換する必要がある場合があります。すべてのデバイスまたはクライアントにインストールされているルート CA 証明書をアップデートして、進行中の接続を安全にし、セキュリティベストプラクティスを最新の状態に保つ必要があります。
注記
デバイスコードで AWS IoT Core に接続するときは、接続に使用している API に証明書を渡します。使用する API は SDK によって異なります。詳細については、「AWS IoT Core デバイス SDK」を参照してください。