SSL 証明書サーバーの名前解決について
安全な Web 通信の領域では、SSL 証明書はサーバーの ID を検証する上で重要な役割を果たします。 。サーバー名解決プロセスは、HTTPS 接続の信頼を確立するために SSL 証明書で指定された名前がどのように使用されるかを決定します。
SSL 証明書サーバー名はどのように解決されますか?
RFC 2818 およびその後継となる RFC 6125 では、サーバー名検証のガイドラインが定義されています。これらの標準では、次のことが指定されています。
Java のSSL 証明書検証メカニズム
Java の SSL メカニズムは subjectAltName 拡張子の優先順位に従います。証明書にこの拡張子が含まれている場合、Java は指定されたドメイン名または IP アドレスを検証用の ID として使用します。それ以外の場合は、CN フィールドの使用に戻ります。この動作は、RFC 2818 で概説されている推奨ベスト プラクティスに従っています。
Keytool を使用した代替名の追加
はい、SSL に代替名を追加することができます。 keytool を使用して証明書を作成します。 Java 7 以降、keytool に「-ext」オプションが導入されました。これにより、証明書にサブジェクト代替名 (SAN) を含めることができます。要件に基づいて、SAN を「dns:www.example.com」または「ip:10.0.0.1」として指定できます。
代替としての OpenSSL
keytool の使用に慣れていない場合は、SAN で SSL 証明書を生成するための OpenSSL が優れたオプションです。 openssl.cnf 構成ファイルを変更すると、「[req]」セクションと「[ v3_req ]」セクションを使用して subjectAltName 拡張子を指定できます。さらに、OPENSSL_CONF 環境変数を使用して、構成ファイルの明示的な場所を指定できます。
問題を解決するには、証明書に正しいサーバー名が含まれていることを確認する必要があります。 CN フィールドに IP アドレスのみが含まれている場合、ブラウザはそれらを受け入れる可能性がありますが、SAN がないため Java はそれらを信頼しません。 keytool または OpenSSL を使用して証明書に SAN を追加すると、ブラウザと Java の両方がサーバー名を正しく認識できるようになります。
以上がJava は SSL 証明書内のサーバー名をどのように解決しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。