「ローカル発行者の証明書を取得できません」エラーについて

王林
リリース: 2024-09-03 15:13:59
オリジナル
364 人が閲覧しました

Understanding the
SSL/TLS の領域では、「ローカル発行者の証明書を取得できません」エラーは、開発者やシステム管理者が安全な接続を使用するときに遭遇する一般的な障害です。このエラーは通常、証明書チェーンを完全に検証できない場合、つまりシステムが発行者を認識できないために証明書の信頼性を検証できない場合に発生します。このエラーを理解することは、SSL/TLS に依存する Web アプリケーション、サーバー、その他のシステムで安全な通信を確保するために重要です。
SSL/TLS とは何ですか?
SSL (Secure Sockets Layer) とその後継である TLS (Transport Layer Security) は、コンピュータ ネットワーク上で安全な通信を提供するために設計された暗号化プロトコルです。これらは、Web トラフィック、電子メール、その他の形式の通信を保護するために広く使用されています。 SSL/TLS の主な目的は、通信セッションの当事者間のプライバシー、データの整合性、認証を確保することです。
SSL/TLS は証明書に依存して信頼を確立します。これらの証明書は、認証局 (CA) として知られる信頼できるエンティティによって発行されます。安全な接続が確立されると、サーバーはその証明書をクライアントに提示し、クライアントはこの証明書を信頼できる CA のリストと照合して検証します。証明書が有効で、CA が信頼されている場合、接続は続行されます。そうしないと、「ローカル発行者の証明書を取得できません」などのエラーが発生する可能性があります。
証明書チェーンの構造
証明書チェーンは証明書パスとも呼ばれ、一連の証明書であり、チェーン内の各証明書は後続の証明書によって署名されます。チェーンはエンドユーザー証明書から始まり、CA によって自己署名されたルート証明書まで続きます。証明書チェーンの一般的な構造には次のものが含まれます:

  1. エンドユーザー証明書: これは、問題の Web サイトまたはサービスの証明書です。
  2. 中間証明書: これらの証明書は、エンドユーザー証明書とルート証明書の間のギャップを埋めます。これらは CA によって発行され、クライアントによって信頼される必要があります。
  3. ルート証明書: ルート証明書はチェーン内の最上位の証明書であり、CA によって自己署名されています。通常、これはシステムの証明書ストアにプリインストールされています。 証明書が信頼されるためには、エンドユーザー証明書からルート証明書までのチェーン全体が有効であり、システムによって認識される必要があります。このチェーン内のリンクが欠落しているか認識されない場合、エラーが発生します。 「ローカル発行者の証明書を取得できません」エラーの原因は何ですか? 「ローカル発行者証明書を取得できません」エラーは、クライアントが信頼ストア内で中間証明書またはルート証明書を見つけることができないために、サーバーによって提示された証明書を検証できない場合に発生します。このエラーはいくつかの要因で発生する可能性があります:
  4. 中間証明書がありません: o サーバーが完全な証明書チェーンを提供できない場合、クライアントは証明書を検証できない可能性があります。これは、サーバーが中間証明書を含めずにエンドユーザー証明書のみを送信する場合によく発生します。
  5. 期限切れまたは不完全な証明書ストア: o クライアントの証明書ストアに必要な中間証明書またはルート証明書がない可能性があります。これは、システムの証明書ストアが古い場合、または必要な証明書がインストールされていない場合に発生する可能性があります。
  6. 自己署名証明書: o 自己署名証明書が使用されており、クライアントがこの証明書を信頼しない場合、接続はこのエラーで失敗します。これは、自己署名証明書がテスト目的で使用される開発環境でよく見られます。
  7. 不適切な構成: o 場合によっては、証明書ファイルへのパスが間違っているなど、サーバー上の構成ミスにより、サーバーが不完全または間違った証明書チェーンを送信する可能性があります。
  8. 期限切れの証明書: o チェーン内の証明書の有効期限が切れている場合、クライアントはチェーンの検証に失敗し、このエラーが発生する可能性があります。 エラーのトラブルシューティングと解決 「ローカル発行者の証明書を取得できません」エラーを解決するには、根本原因に応じていくつかの手順を実行できます。
  9. 完全な証明書チェーンが送信されていることを確認します。 o サーバーは、エンドユーザー証明書とすべての中間証明書を含む完全な証明書チェーンを送信するように構成する必要があります。これは通常、証明書を 1 つのファイルに連結するか、必要なすべての証明書を参照するようにサーバー ソフトウェアが構成されていることを確認することによって行われます。
  10. クライアントの証明書ストアを更新します。 o クライアントの証明書ストアが古い場合は、最新の証明書で更新する必要があります。ほとんどのオペレーティング システムでは、これはパッケージ マネージャーまたはシステム アップデートを通じて実行できます。たとえば、Linux では、ca-certificates パッケージを更新すると、証明書ストアを更新できます。
  11. 不足している証明書を手動で追加します: o 特定の中間証明書またはルート証明書が見つからない場合は、それらをクライアントの証明書ストアに手動で追加できます。これは、CA の Web サイトから不足している証明書を取得し、トラスト ストアにインストールすることによって行われます。
  12. 期限切れの証明書を確認します: o OpenSSL などのツールを使用して、チェーン内の証明書の有効性を確認します。有効期限が切れた証明書がある場合は、更新または交換する必要があります。
  13. 正しいサーバー構成を使用してください: o サーバーが正しい証明書ファイルを指すように正しく構成されていることを確認します。サーバーの SSL/TLS 構成をチェックして、証明書パスが正しく設定されていること、およびファイルがアクセス可能であることを確認します。
  14. 信頼できる CA に切り替えます: o 自己署名証明書が問題の原因となっている場合は、信頼できる CA によって発行された証明書に切り替えることを検討してください。現在、多くのサービスが無料の SSL/TLS 証明書 (Let's Encrypt など) を提供しており、ほとんどのクライアントで簡単にインストールして認識できます。 エラーを診断するためのツール 「ローカル発行者の証明書を取得できません」エラーの診断と修正に役立つツールがいくつかあります:
  15. OpenSSL: o OpenSSL は、SSL/TLS 証明書の管理とトラブルシューティングに広く使用されているツールです。 openssl s_client -connect のようなコマンドを使用して、サーバーによって提示された証明書チェーンを検査できます。
  16. SSL Labs SSL テスト: o SSL Labs SSL テストは、サーバーの SSL/TLS 構成を分析し、証明書チェーンと潜在的な問題に関する詳細情報を提供するオンライン サービスです。
  17. 詳細オプションを使用したカール: o コマンドライン ツール Curl を -v オプションとともに使用すると、SSL/TLS ハンドシェイク プロセスに関する洞察が得られ、証明書の検証が失敗している場所を正確に特定できます。
  18. ブラウザ開発者ツール: o 最新の Web ブラウザには、セキュリティ パネルを含む開発者ツールが付属しています。これらを使用すると、Web サイトの証明書チェーンを検査し、不足している証明書または信頼できない証明書を特定できます。 結論 「ローカル発行者の証明書を取得できません」エラーは、SSL/TLS を使用するときに、特に安全な通信が重要な環境で発生する一般的な問題です。証明書チェーンの構造とこのエラーの原因となる要因を理解することで、問題を効果的に診断して解決できます。クライアントの証明書ストアを更新する場合でも、完全な証明書チェーンが送信されるようにする場合でも、信頼できる CA に切り替える場合でも、この問題を軽減し、安全で信頼性の高い通信を確保するために利用できる戦略がいくつかあります。

以上が「ローカル発行者の証明書を取得できません」エラーについての詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:dev.to
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!